Improve name: "count-one-bits" is better than "popcount".
[gnulib.git] / tests / test-mbscasestr4.c
1 /* Test of case-insensitive searching in a string.
2    Copyright (C) 2007 Free Software Foundation, Inc.
3
4    This program is free software; you can redistribute it and/or modify
5    it under the terms of the GNU General Public License as published by
6    the Free Software Foundation; either version 2, or (at your option)
7    any later version.
8
9    This program is distributed in the hope that it will be useful,
10    but WITHOUT ANY WARRANTY; without even the implied warranty of
11    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12    GNU General Public License for more details.
13
14    You should have received a copy of the GNU General Public License
15    along with this program; if not, write to the Free Software Foundation,
16    Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.  */
17
18 /* Written by Bruno Haible <bruno@clisp.org>, 2007.  */
19
20 #include <config.h>
21
22 #include <string.h>
23
24 #include <locale.h>
25 #include <stdio.h>
26 #include <stdlib.h>
27
28 #define ASSERT(expr) \
29   do                                                                         \
30     {                                                                        \
31       if (!(expr))                                                           \
32         {                                                                    \
33           fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \
34           abort ();                                                          \
35         }                                                                    \
36     }                                                                        \
37   while (0)
38
39 int
40 main ()
41 {
42   /* configure should already have checked that the locale is supported.  */
43   if (setlocale (LC_ALL, "") == NULL)
44     return 1;
45
46   {
47     const char input[] = "GOLD NEEDLE BEATS TIN NEEDLE";
48     ASSERT (mbscasestr (input, "Needle") == input + 5);
49   }
50
51   /* The following tests show how mbscasestr() is different from
52      strcasestr().  */
53
54   {
55     const char input[] = "s\303\266zc\303\274k"; /* sözcük */
56     ASSERT (mbscasestr (input, "\303\266z") == input + 1);
57     ASSERT (mbscasestr (input, "\303\266c") == NULL);
58   }
59
60   /* This test shows how a string of larger size can be found in a string of
61      smaller size.  */
62   {
63     const char input[] = "*Tbilisi imini*";
64     ASSERT (mbscasestr (input, "TB\304\260L\304\260S\304\260 \304\260m\304\260n\304\260") == input + 1); /* TBİLİSİ İmİnİ */
65   }
66
67   return 0;
68 }