Fix csqrt spurious underflows (bug 18823).
[glibc.git] / wcsmbs / wcpncpy.c
blob98c77a501c16debdacaeb33d11272e49c90d0e51
1 /* Copyright (C) 1996-2015 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
3 Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <http://www.gnu.org/licenses/>. */
19 #include <wchar.h>
22 /* Copy no more than N wide-characters of SRC to DEST, returning the
23 address of the last character written into DEST. */
24 wchar_t *
25 __wcpncpy (dest, src, n)
26 wchar_t *dest;
27 const wchar_t *src;
28 size_t n;
30 wint_t c;
31 wchar_t *const s = dest;
33 if (n >= 4)
35 size_t n4 = n >> 2;
37 for (;;)
39 c = *src++;
40 *dest++ = c;
41 if (c == L'\0')
42 break;
43 c = *src++;
44 *dest++ = c;
45 if (c == L'\0')
46 break;
47 c = *src++;
48 *dest++ = c;
49 if (c == L'\0')
50 break;
51 c = *src++;
52 *dest++ = c;
53 if (c == L'\0')
54 break;
55 if (--n4 == 0)
56 goto last_chars;
58 n -= dest - s;
59 goto zero_fill;
62 last_chars:
63 n &= 3;
64 if (n == 0)
65 return dest;
67 for (;;)
69 c = *src++;
70 --n;
71 *dest++ = c;
72 if (c == L'\0')
73 break;
74 if (n == 0)
75 return dest;
78 zero_fill:
79 while (n-- > 0)
80 dest[n] = L'\0';
82 return dest - 1;
85 weak_alias (__wcpncpy, wcpncpy)