
1: /* Copyright (C) 1993, 95, 96, 97, 98, 99, 2005 Free Software Foundation, Inc. 2: This file is part of the GNU C Library. 3: 4: The GNU C Library is free software; you can redistribute it and/or 5: modify it under the terms of the GNU Lesser General Public 6: License as published by the Free Software Foundation; either 7: version 2.1 of the License, or (at your option) any later version. 8: 9: The GNU C Library is distributed in the hope that it will be useful, 10: but WITHOUT ANY WARRANTY; without even the implied warranty of 11: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 12: Lesser General Public License for more details. 13: 14: You should have received a copy of the GNU Lesser General Public 15: License along with the GNU C Library; if not, write to the Free 16: Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 17: 02111-1307 USA. 18: 19: As a special exception, if you link the code in this file with 20: files compiled with a GNU compiler to produce an executable, 21: that does not cause the resulting executable to be covered by 22: the GNU Lesser General Public License. This exception does not 23: however invalidate any other reasons why the executable file 24: might be covered by the GNU Lesser General Public License. 25: This exception applies to code released by its copyright holders 26: in files containing the exception. */ 27: 28: #include "libioP.h" 29: #include <wchar.h> 30: #include <sys/param.h> 31: 32: wchar_t * 33: __fgetws_unlocked_chk (wchar_t *buf, size_t size, int n, _IO_FILE *fp) 34: { 35: _IO_size_t count; 36: wchar_t *result; 37: int old_error; 38: CHECK_FILE (fp, NULL); 39: if (n <= 0) 40: return NULL; 41: /* This is very tricky since a file descriptor may be in the 42: non-blocking mode. The error flag doesn't mean much in this 43: case. We return an error only when there is a new error. */ 44: old_error = fp->_IO_file_flags & _IO_ERR_SEEN; 45: fp->_IO_file_flags &= ~_IO_ERR_SEEN; 46: count = _IO_getwline (fp, buf, MIN ((size_t) n - 1, size), L'\n', 1); 47: /* If we read in some bytes and errno is EAGAIN, that error will 48: be reported for next read. */ 49: if (count == 0 || ((fp->_IO_file_flags & _IO_ERR_SEEN) 50: && errno != EAGAIN)) 51: result = NULL; 52: else if (count >= size) 53: __chk_fail (); 54: else 55: { 56: buf[count] = '\0'; 57: result = buf; 58: } 59: fp->_IO_file_flags |= old_error; 60: return result; 61: }