From a04720d334199b3f995b8ff9f3e27793ff4bb09a Mon Sep 17 00:00:00 2001 From: Bruno Haible Date: Mon, 23 Apr 2007 08:47:17 +0000 Subject: [PATCH] Free a malloc()ed ungetc buffer. --- ChangeLog | 5 +++++ lib/fpurge.c | 22 +++++++++++++++++++++- 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index 0d906d844..f5a0210c5 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,10 @@ 2007-04-23 Bruno Haible + * lib/fpurge.c (fpurge) [glibc, BSD]: Free a malloc()ed ungetc buffer. + Reported by Eric Blake. + +2007-04-23 Bruno Haible + * lib/fbufmode.c (fbufmode): Port to Solaris/SPARC64. 2007-04-23 Bruno Haible diff --git a/lib/fpurge.c b/lib/fpurge.c index c4572faff..0e8c164e2 100644 --- a/lib/fpurge.c +++ b/lib/fpurge.c @@ -29,6 +29,12 @@ fpurge (FILE *fp) #if defined _IO_ferror_unlocked /* GNU libc, BeOS */ fp->_IO_read_end = fp->_IO_read_ptr; fp->_IO_write_ptr = fp->_IO_write_base; + /* Avoid memory leak when there is an active ungetc buffer. */ + if (fp->_IO_save_base != NULL) + { + free (fp->_IO_save_base); + fp->_IO_save_base = NULL; + } return 0; #elif defined __sferror /* FreeBSD, NetBSD, OpenBSD, MacOS X, Cygwin */ fp->_p = fp->_bf._base; @@ -36,6 +42,20 @@ fpurge (FILE *fp) fp->_w = ((fp->_flags & (__SLBF | __SNBF)) == 0 /* fully buffered? */ ? fp->_bf._size : 0); + /* Avoid memory leak when there is an active ungetc buffer. */ +# if defined __NetBSD__ || defined __OpenBSD__ /* NetBSD, OpenBSD */ + /* See + and */ +# define fp_ub ((struct { struct __sbuf _ub; } *) fp->_ext._base)->_ub +# else /* FreeBSD, MacOS X, Cygwin */ +# define fp_ub fp->_ub +# endif + if (fp_ub._base != NULL) + { + if (fp_ub._base != fp->_ubuf) + free (fp_ub._base); + fp_ub._base = NULL; + } return 0; #elif defined _IOERR /* AIX, HP-UX, IRIX, OSF/1, Solaris, mingw */ fp->_ptr = fp->_base; @@ -43,6 +63,6 @@ fpurge (FILE *fp) fp->_cnt = 0; return 0; #else - #error "Please port gnulib fpurge.c to your platform!" + #error "Please port gnulib fpurge.c to your platform! Look at the definitions of fflush, setvbuf and ungetc on your system, then report this to bug-gnulib." #endif } -- 2.11.0