]> git.ipfire.org Git - thirdparty/glibc.git/blame - libio/iofgetws_u.c
Update copyright notices with scripts/update-copyrights
[thirdparty/glibc.git] / libio / iofgetws_u.c
CommitLineData
d4697bc9 1/* Copyright (C) 1993-2014 Free Software Foundation, Inc.
41bdb6e2 2 This file is part of the GNU C Library.
d64b6ad0 3
41bdb6e2
AJ
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.
d64b6ad0 8
41bdb6e2
AJ
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
d64b6ad0 11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
41bdb6e2 12 Lesser General Public License for more details.
d64b6ad0 13
41bdb6e2 14 You should have received a copy of the GNU Lesser General Public
59ba27a6
PE
15 License along with the GNU C Library; if not, see
16 <http://www.gnu.org/licenses/>.
d64b6ad0 17
41bdb6e2
AJ
18 As a special exception, if you link the code in this file with
19 files compiled with a GNU compiler to produce an executable,
20 that does not cause the resulting executable to be covered by
21 the GNU Lesser General Public License. This exception does not
22 however invalidate any other reasons why the executable file
23 might be covered by the GNU Lesser General Public License.
24 This exception applies to code released by its copyright holders
25 in files containing the exception. */
d64b6ad0
UD
26
27#include "libioP.h"
28#include <wchar.h>
29
30wchar_t *
31fgetws_unlocked (buf, n, fp)
32 wchar_t *buf;
33 int n;
34 _IO_FILE *fp;
35{
36 _IO_size_t count;
37 wchar_t *result;
38 int old_error;
39 CHECK_FILE (fp, NULL);
40 if (n <= 0)
41 return NULL;
b5d839c9
UD
42 if (__builtin_expect (n == 1, 0))
43 {
44 /* Another irregular case: since we have to store a NUL byte and
45 there is only room for exactly one byte, we don't have to
46 read anything. */
47 buf[0] = L'\0';
48 return buf;
49 }
d64b6ad0
UD
50 /* This is very tricky since a file descriptor may be in the
51 non-blocking mode. The error flag doesn't mean much in this
52 case. We return an error only when there is a new error. */
53 old_error = fp->_IO_file_flags & _IO_ERR_SEEN;
54 fp->_IO_file_flags &= ~_IO_ERR_SEEN;
55 count = _IO_getwline (fp, buf, n - 1, L'\n', 1);
56 /* If we read in some bytes and errno is EAGAIN, that error will
57 be reported for next read. */
58 if (count == 0 || ((fp->_IO_file_flags & _IO_ERR_SEEN)
350635a5 59 && errno != EAGAIN))
d64b6ad0
UD
60 result = NULL;
61 else
62 {
63 buf[count] = '\0';
64 result = buf;
65 }
66 fp->_IO_file_flags |= old_error;
67 return result;
68}