]> git.ipfire.org Git - thirdparty/glibc.git/blame - libio/iofgetws_u.c
Update copyright dates with scripts/update-copyrights.
[thirdparty/glibc.git] / libio / iofgetws_u.c
CommitLineData
04277e02 1/* Copyright (C) 1993-2019 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 *
9964a145 31fgetws_unlocked (wchar_t *buf, int n, FILE *fp)
d64b6ad0 32{
9964a145 33 size_t count;
d64b6ad0
UD
34 wchar_t *result;
35 int old_error;
36 CHECK_FILE (fp, NULL);
37 if (n <= 0)
38 return NULL;
a1ffb40e 39 if (__glibc_unlikely (n == 1))
b5d839c9
UD
40 {
41 /* Another irregular case: since we have to store a NUL byte and
42 there is only room for exactly one byte, we don't have to
43 read anything. */
44 buf[0] = L'\0';
45 return buf;
46 }
d64b6ad0
UD
47 /* This is very tricky since a file descriptor may be in the
48 non-blocking mode. The error flag doesn't mean much in this
49 case. We return an error only when there is a new error. */
df6c012b
ZW
50 old_error = fp->_flags & _IO_ERR_SEEN;
51 fp->_flags &= ~_IO_ERR_SEEN;
d64b6ad0
UD
52 count = _IO_getwline (fp, buf, n - 1, L'\n', 1);
53 /* If we read in some bytes and errno is EAGAIN, that error will
54 be reported for next read. */
df6c012b 55 if (count == 0 || ((fp->_flags & _IO_ERR_SEEN) && errno != EAGAIN))
d64b6ad0
UD
56 result = NULL;
57 else
58 {
59 buf[count] = '\0';
60 result = buf;
61 }
df6c012b 62 fp->_flags |= old_error;
d64b6ad0
UD
63 return result;
64}