Mail Archives: djgpp-workers/2004/11/26/05:25:39
On Fri, 26 Nov 2004, Eli Zaretskii wrote:
> If you remove the fclose, please put an fflush there, in case there's
> something buffered left. (I know it shouldn't happen, but better be
> safe than sorry.)
Yes. Here's the patch; I changed the l1->fp to stdout/stdin to avoid
confusion. BTW, does setting _IORMONCL around system() have any real
effect? Is there any real chance that the program could crash inside
system (by the child program or otherwise) and yes be able to remove
the temproary file?
Index: popen.c
===================================================================
RCS file: /cvs/djgpp/djgpp/src/libc/posix/stdio/popen.c,v
retrieving revision 1.6
diff -u -r1.6 popen.c
--- popen.c 1 Jun 2004 07:59:03 -0000 1.6
+++ popen.c 26 Nov 2004 10:16:39 -0000
@@ -102,22 +102,22 @@
goto error;
/* redirect stdout */
- if (!(l1->fp = freopen(temp_name, "wb", stdout)))
+ if (!freopen(temp_name, "wb", stdout))
goto error;
/* make sure file is removed on abnormal exit */
- l1->fp->_flag |= _IORMONCL;
- l1->fp->_name_to_remove = temp_name;
+ stdout->_flag |= _IORMONCL;
+ stdout->_name_to_remove = temp_name;
/* execute command */
l1->exit_status = system(cm);
- /* don't remove file while closing */
- l1->fp->_flag &= ~_IORMONCL;
- l1->fp->_name_to_remove = NULL;
+ /* don't remove file */
+ stdout->_flag &= ~_IORMONCL;
+ stdout->_name_to_remove = NULL;
- /* close file */
- fclose(l1->fp);
+ /* flush file just in case */
+ fflush(stdout);
/* reopen real stdout */
if (dup2(fd, fileno(stdout)) == -1)
@@ -205,17 +205,25 @@
goto exit;
/* redirect stdin */
- if (!(l1->fp = freopen(temp_name, "rb", stdin)))
+ if (!freopen(temp_name, "rb", stdin))
goto exit;
/* make sure file is removed on abnormal exit */
- l1->fp->_flag |= _IORMONCL;
- l1->fp->_name_to_remove = temp_name;
+ stdin->_flag |= _IORMONCL;
+ stdin->_name_to_remove = temp_name;
/* execute command */
retval = system(l1->command);
- /* reopen stdin */
+ /* don't remove file */
+ stdin->_flag &= ~_IORMONCL;
+ stdin->_name_to_remove = NULL;
+
+ /* close and remove file */
+ close(fileno(stdin));
+ remove(temp_name);
+
+ /* reopen real stdin */
if (dup2(fd, fileno(stdin)) == -1)
{
retval = -1;
@@ -227,16 +235,18 @@
}
/* if pipe was opened to read, return the exit status we saved */
else if (l1->mode[0] == 'r')
+ {
retval = l1->exit_status;
+
+ /* close and remove file */
+ fclose(l1->fp);
+ }
else
/* invalid mode */
retval = -1;
exit:
- /* close and remove file */
- fclose(l1->fp);
-
if (l1->command)
free(l1->command);
--
Esa Peuha
student of mathematics at the University of Helsinki
http://www.helsinki.fi/~peuha/
- Raw text -