m68k: use math_force_eval in nextafterl
[glibc.git] / wcsmbs / wcsncmp.c
blob35ab2c95f8fe4da5bcd98cc393b88c3e41d26f6f
1 /* Copyright (C) 1995-2013 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 /* Compare no more than N characters of S1 and S2,
23 returning less than, equal to or greater than zero
24 if S1 is lexicographically less than, equal to or
25 greater than S2. */
26 int
27 wcsncmp (s1, s2, n)
28 const wchar_t *s1;
29 const wchar_t *s2;
30 size_t n;
32 wint_t c1 = L'\0';
33 wint_t c2 = L'\0';
35 if (n >= 4)
37 size_t n4 = n >> 2;
40 c1 = (wint_t) *s1++;
41 c2 = (wint_t) *s2++;
42 if (c1 == L'\0' || c1 != c2)
43 return c1 - c2;
44 c1 = (wint_t) *s1++;
45 c2 = (wint_t) *s2++;
46 if (c1 == L'\0' || c1 != c2)
47 return c1 - c2;
48 c1 = (wint_t) *s1++;
49 c2 = (wint_t) *s2++;
50 if (c1 == L'\0' || c1 != c2)
51 return c1 - c2;
52 c1 = (wint_t) *s1++;
53 c2 = (wint_t) *s2++;
54 if (c1 == L'\0' || c1 != c2)
55 return c1 - c2;
56 } while (--n4 > 0);
57 n &= 3;
60 while (n > 0)
62 c1 = (wint_t) *s1++;
63 c2 = (wint_t) *s2++;
64 if (c1 == L'\0' || c1 != c2)
65 return c1 - c2;
66 n--;
69 return c1 - c2;