]> git.ipfire.org Git - thirdparty/glibc.git/blame - wcsmbs/wcsncmp.c
Update.
[thirdparty/glibc.git] / wcsmbs / wcsncmp.c
CommitLineData
299a95b9 1/* Copyright (C) 1995, 1996 Free Software Foundation, Inc.
6d52618b
UD
2 This file is part of the GNU C Library.
3 Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995.
a482b5a5 4
6d52618b
UD
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Library General Public License as
7 published by the Free Software Foundation; either version 2 of the
8 License, or (at your option) any later version.
a482b5a5 9
6d52618b
UD
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 Library General Public License for more details.
a482b5a5 14
6d52618b
UD
15 You should have received a copy of the GNU Library General Public
16 License along with the GNU C Library; see the file COPYING.LIB. If not,
17 write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 Boston, MA 02111-1307, USA. */
a482b5a5 19
299a95b9 20#include <wchar.h>
a482b5a5
RM
21
22
23/* Compare no more than N characters of S1 and S2,
24 returning less than, equal to or greater than zero
6d52618b 25 if S1 is lexicographically less than, equal to or
a482b5a5
RM
26 greater than S2. */
27int
28wcsncmp (s1, s2, n)
299a95b9
RM
29 const wchar_t *s1;
30 const wchar_t *s2;
31 size_t n;
a482b5a5 32{
59dd8641
RM
33 wint_t c1 = L'\0';
34 wint_t c2 = L'\0';
a482b5a5
RM
35
36 if (n >= 4)
37 {
38 size_t n4 = n >> 2;
39 do
40 {
59dd8641
RM
41 c1 = (wint_t) *s1++;
42 c2 = (wint_t) *s2++;
a482b5a5
RM
43 if (c1 == L'\0' || c1 != c2)
44 return c1 - c2;
59dd8641
RM
45 c1 = (wint_t) *s1++;
46 c2 = (wint_t) *s2++;
a482b5a5
RM
47 if (c1 == L'\0' || c1 != c2)
48 return c1 - c2;
59dd8641
RM
49 c1 = (wint_t) *s1++;
50 c2 = (wint_t) *s2++;
a482b5a5
RM
51 if (c1 == L'\0' || c1 != c2)
52 return c1 - c2;
59dd8641
RM
53 c1 = (wint_t) *s1++;
54 c2 = (wint_t) *s2++;
a482b5a5
RM
55 if (c1 == L'\0' || c1 != c2)
56 return c1 - c2;
57 } while (--n4 > 0);
58 n &= 3;
59 }
60
61 while (n > 0)
62 {
59dd8641
RM
63 c1 = (wint_t) *s1++;
64 c2 = (wint_t) *s2++;
a482b5a5
RM
65 if (c1 == L'\0' || c1 != c2)
66 return c1 - c2;
67 n--;
68 }
69
70 return c1 - c2;
71}