X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fmbspbrk.c;h=173c8032c4988a8219eb50e0fd0cbcdfe41c0fe8;hb=533101a268dc5015a140ff4695d8eeb04fbe57b6;hp=cc731868fcbe9ebbc10259698100c29a39f70efc;hpb=33a590e2d5c2f27dda24cdb16c5028857ed7d7e4;p=gnulib.git diff --git a/lib/mbspbrk.c b/lib/mbspbrk.c index cc731868f..173c8032c 100644 --- a/lib/mbspbrk.c +++ b/lib/mbspbrk.c @@ -1,11 +1,11 @@ /* Searching a string for a character among a given set of characters. - Copyright (C) 1999, 2002, 2006-2007 Free Software Foundation, Inc. + Copyright (C) 1999, 2002, 2006-2013 Free Software Foundation, Inc. Written by Bruno Haible , 2007. - This program is free software; you can redistribute it and/or modify + This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2, or (at your option) - any later version. + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -13,17 +13,14 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software Foundation, - Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ + along with this program. If not, see . */ #include /* Specification. */ #include -#if HAVE_MBRTOWC -# include "mbuiter.h" -#endif +#include "mbuiter.h" /* Find the first occurrence in the character string STRING of any character in the character string ACCEPT. Return the pointer to it, or NULL if none @@ -37,32 +34,30 @@ mbspbrk (const char *string, const char *accept) if (accept[1] == '\0') return mbschr (string, accept[0]); /* General case. */ -#if HAVE_MBRTOWC if (MB_CUR_MAX > 1) { mbui_iterator_t iter; for (mbui_init (iter, string); mbui_avail (iter); mbui_advance (iter)) - { - if (mb_len (mbui_cur (iter)) == 1) - { - if (mbschr (accept, (unsigned char) * mbui_cur_ptr (iter))) - return (char *) mbui_cur_ptr (iter); - } - else - { - mbui_iterator_t aiter; - - for (mbui_init (aiter, accept); - mbui_avail (aiter); - mbui_advance (aiter)) - if (mb_equal (mbui_cur (aiter), mbui_cur (iter))) - return (char *) mbui_cur_ptr (iter); - } - } + { + if (mb_len (mbui_cur (iter)) == 1) + { + if (mbschr (accept, * mbui_cur_ptr (iter))) + return (char *) mbui_cur_ptr (iter); + } + else + { + mbui_iterator_t aiter; + + for (mbui_init (aiter, accept); + mbui_avail (aiter); + mbui_advance (aiter)) + if (mb_equal (mbui_cur (aiter), mbui_cur (iter))) + return (char *) mbui_cur_ptr (iter); + } + } return NULL; } else -#endif return strpbrk (string, accept); }