* libc/stdio/refill.c (__srefill): Try again after EOF on Cygwin. Clear EOF
flag if successful.
This commit is contained in:
		| @@ -1,3 +1,8 @@ | |||||||
|  | 2004-11-17  Christopher Faylor  <cgf@timesys.com> | ||||||
|  |  | ||||||
|  | 	* libc/stdio/refill.c (__srefill): Try again after EOF on Cygwin.  Clear | ||||||
|  | 	EOF flag if successful. | ||||||
|  |  | ||||||
| 2004-10-28  Christopher Faylor  <cgf@timesys.com> | 2004-10-28  Christopher Faylor  <cgf@timesys.com> | ||||||
|  |  | ||||||
| 	* libc/include/sys/signal.h: Move <signal.h> include to bottom of file | 	* libc/include/sys/signal.h: Move <signal.h> include to bottom of file | ||||||
|   | |||||||
| @@ -45,9 +45,11 @@ _DEFUN(__srefill, (fp), | |||||||
|  |  | ||||||
|   fp->_r = 0;			/* largely a convenience for callers */ |   fp->_r = 0;			/* largely a convenience for callers */ | ||||||
|  |  | ||||||
|  | #ifndef __CYGWIN__ | ||||||
|   /* SysV does not make this test; take it out for compatibility */ |   /* SysV does not make this test; take it out for compatibility */ | ||||||
|   if (fp->_flags & __SEOF) |   if (fp->_flags & __SEOF) | ||||||
|     return EOF; |     return EOF; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|   /* if not already reading, have to be reading and writing */ |   /* if not already reading, have to be reading and writing */ | ||||||
|   if ((fp->_flags & __SRD) == 0) |   if ((fp->_flags & __SRD) == 0) | ||||||
| @@ -98,7 +100,13 @@ _DEFUN(__srefill, (fp), | |||||||
|   fp->_p = fp->_bf._base; |   fp->_p = fp->_bf._base; | ||||||
|   fp->_r = (*fp->_read) (fp->_cookie, (char *) fp->_p, fp->_bf._size); |   fp->_r = (*fp->_read) (fp->_cookie, (char *) fp->_p, fp->_bf._size); | ||||||
|   fp->_flags &= ~__SMOD;	/* buffer contents are again pristine */ |   fp->_flags &= ~__SMOD;	/* buffer contents are again pristine */ | ||||||
|  | #ifndef __CYGWIN__ | ||||||
|   if (fp->_r <= 0) |   if (fp->_r <= 0) | ||||||
|  | #else | ||||||
|  |   if (fp->_r > 0) | ||||||
|  |     fp->_flags &= ~__SEOF; | ||||||
|  |   else | ||||||
|  | #endif | ||||||
|     { |     { | ||||||
|       if (fp->_r == 0) |       if (fp->_r == 0) | ||||||
| 	fp->_flags |= __SEOF; | 	fp->_flags |= __SEOF; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user