annotate lib/mbsspn.c @ 8105:43f02832d528

New module 'mbsspn'.
author Bruno Haible <bruno@clisp.org>
date Mon, 05 Feb 2007 03:23:34 +0000
parents
children fccfb6a55bab
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
8105
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
1 /* Searching a string for a character outside a given set of characters.
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
2 Copyright (C) 1999, 2002, 2006-2007 Free Software Foundation, Inc.
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
3 Written by Bruno Haible <bruno@clisp.org>, 2007.
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
4
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
5 This program is free software; you can redistribute it and/or modify
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
6 it under the terms of the GNU General Public License as published by
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
7 the Free Software Foundation; either version 2, or (at your option)
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
8 any later version.
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
9
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
10 This program is distributed in the hope that it will be useful,
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
13 GNU General Public License for more details.
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
14
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
15 You should have received a copy of the GNU General Public License
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
16 along with this program; if not, write to the Free Software Foundation,
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
17 Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
18
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
19 #include <config.h>
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
20
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
21 /* Specification. */
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
22 #include <string.h>
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
23
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
24 #if HAVE_MBRTOWC
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
25 # include "mbuiter.h"
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
26 #endif
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
27
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
28 /* Find the first occurrence in the character string STRING of any character
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
29 not in the character string REJECT. Return the number of bytes from the
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
30 beginning of the string to this occurrence, or to the end of the string
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
31 if none exists. */
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
32 size_t
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
33 mbsspn (const char *string, const char *reject)
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
34 {
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
35 /* Optimize two cases. */
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
36 if (reject[0] == '\0')
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
37 return 0;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
38 if (reject[1] == '\0')
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
39 {
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
40 unsigned char uc = (unsigned char) reject[0];
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
41
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
42 #if HAVE_MBRTOWC
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
43 if (MB_CUR_MAX > 1)
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
44 {
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
45 mbui_iterator_t iter;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
46
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
47 for (mbui_init (iter, string); mbui_avail (iter); mbui_advance (iter))
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
48 if (!(mb_len (mbui_cur (iter)) == 1
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
49 && (unsigned char) * mbui_cur_ptr (iter) == uc))
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
50 return mbui_cur_ptr (iter) - string;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
51 return strlen (string);
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
52 }
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
53 else
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
54 #endif
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
55 {
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
56 const char *ptr;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
57
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
58 for (ptr = string; *ptr != '\0'; ptr++)
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
59 if ((unsigned char) *ptr != uc)
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
60 break;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
61 return ptr - string;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
62 }
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
63 }
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
64 /* General case. */
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
65 #if HAVE_MBRTOWC
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
66 if (MB_CUR_MAX > 1)
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
67 {
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
68 mbui_iterator_t iter;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
69
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
70 for (mbui_init (iter, string); mbui_avail (iter); mbui_advance (iter))
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
71 {
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
72 if (mb_len (mbui_cur (iter)) == 1)
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
73 {
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
74 if (mbschr (reject, (unsigned char) * mbui_cur_ptr (iter)) == NULL)
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
75 return mbui_cur_ptr (iter) - string;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
76 }
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
77 else
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
78 {
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
79 mbui_iterator_t aiter;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
80
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
81 for (mbui_init (aiter, reject);
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
82 mbui_avail (aiter);
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
83 mbui_advance (aiter))
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
84 {
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
85 if (!mbui_avail (aiter))
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
86 return mbui_cur_ptr (iter) - string;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
87 if (mb_equal (mbui_cur (aiter), mbui_cur (iter)))
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
88 break;
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
89 }
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
90 }
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
91 }
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
92 return strlen (string);
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
93 }
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
94 else
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
95 #endif
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
96 return strspn (string, reject);
43f02832d528 New module 'mbsspn'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
97 }