diff --git a/qse/include/qse/cmn/str.h b/qse/include/qse/cmn/str.h index 3a97f251..594f20dc 100644 --- a/qse/include/qse/cmn/str.h +++ b/qse/include/qse/cmn/str.h @@ -1,5 +1,5 @@ /* - * $Id: str.h 415 2011-03-25 16:02:04Z hyunghwan.chung $ + * $Id: str.h 416 2011-03-27 05:04:24Z hyunghwan.chung $ * Copyright 2006-2009 Chung, Hyung-Hwan. This file is part of QSE. @@ -723,34 +723,58 @@ qse_wchar_t* qse_wcschr ( qse_wcint_t c ); +qse_mchar_t* qse_mbsxchr ( + const qse_mchar_t* str, + qse_size_t len, + qse_mcint_t c +); + +qse_wchar_t* qse_wcsxchr ( + const qse_wchar_t* str, + qse_size_t len, + qse_wcint_t c +); + +qse_wchar_t* qse_wcsrchr ( + const qse_wchar_t* str, + qse_wcint_t c +); + +qse_mchar_t* qse_mbsrchr ( + const qse_mchar_t* str, + qse_mcint_t c +); + +qse_mchar_t* qse_mbsxrchr ( + const qse_mchar_t* str, + qse_size_t len, + qse_mcint_t c +); + +qse_wchar_t* qse_wcsxrchr ( + const qse_wchar_t* str, + qse_size_t len, + qse_wcint_t c +); + #ifdef QSE_CHAR_IS_MCHAR -# define qse_strchr(str,c) qse_mbschr(str,c) +# define qse_strchr(str,c) qse_mbschr(str,c) +# define qse_strxchr(str,len,c) qse_mbsxchr(str,len,c) +# define qse_strrchr(str,c) qse_mbsrchr(str,c) +# define qse_strxrchr(str,len,c) qse_mbsxrchr(str,len,c) #else -# define qse_strchr(str,c) qse_wcschr(str,c) +# define qse_strchr(str,c) qse_wcschr(str,c) +# define qse_strxchr(str,len,c) qse_wcsxchr(str,len,c) +# define qse_strrchr(str,c) qse_wcsrchr(str,c) +# define qse_strxrrchr(str,len,c) qse_wcsxrchr(str,len,c) #endif -qse_char_t* qse_strxchr ( - const qse_char_t* str, - qse_size_t len, - qse_cint_t c -); - -qse_char_t* qse_strrchr ( - const qse_char_t* str, - qse_cint_t c -); - -qse_char_t* qse_strxrchr ( - const qse_char_t* str, - qse_size_t len, - qse_cint_t c -); /** * The qse_strxword() function finds a whole word in a string. */ const qse_char_t* qse_strxword ( - const qse_char_t* str, + const qse_char_t* str, qse_size_t len, const qse_char_t* word ); @@ -760,7 +784,7 @@ const qse_char_t* qse_strxword ( * case-insensitively. */ const qse_char_t* qse_strxcaseword ( - const qse_char_t* str, + const qse_char_t* str, qse_size_t len, const qse_char_t* word ); diff --git a/qse/lib/cmn/Makefile.am b/qse/lib/cmn/Makefile.am index dea64d81..68778d4f 100644 --- a/qse/lib/cmn/Makefile.am +++ b/qse/lib/cmn/Makefile.am @@ -9,7 +9,7 @@ lib_LTLIBRARIES = libqsecmn.la libqsecmn_la_SOURCES = \ syscall.h mem.h \ mem.c xma.c fma.c chr.c chr_cnv.c rex.c \ - str_bas.c str_cnv.c str_cmp.c str_cpy.c str_dyn.c str_fcpy.c \ + str_bas.c str_chr.c str_cnv.c str_cmp.c str_cpy.c str_dyn.c str_fcpy.c \ str_pbrk.c str_put.c str_spn.c str_utl.c \ lda.c oht.c htb.c rbt.c sll.c gdl.c dll.c opt.c \ tio.c tio_get.c tio_put.c \ diff --git a/qse/lib/cmn/Makefile.in b/qse/lib/cmn/Makefile.in index eb21742e..9a1f1db0 100644 --- a/qse/lib/cmn/Makefile.in +++ b/qse/lib/cmn/Makefile.in @@ -73,11 +73,12 @@ am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) libqsecmn_la_DEPENDENCIES = am_libqsecmn_la_OBJECTS = mem.lo xma.lo fma.lo chr.lo chr_cnv.lo \ - rex.lo str_bas.lo str_cnv.lo str_cmp.lo str_cpy.lo str_dyn.lo \ - str_fcpy.lo str_pbrk.lo str_put.lo str_spn.lo str_utl.lo \ - lda.lo oht.lo htb.lo rbt.lo sll.lo gdl.lo dll.lo opt.lo tio.lo \ - tio_get.lo tio_put.lo fio.lo pio.lo sio.lo alg_search.lo \ - alg_sort.lo time.lo misc.lo assert.lo main.lo stdio.lo + rex.lo str_bas.lo str_chr.lo str_cnv.lo str_cmp.lo str_cpy.lo \ + str_dyn.lo str_fcpy.lo str_pbrk.lo str_put.lo str_spn.lo \ + str_utl.lo lda.lo oht.lo htb.lo rbt.lo sll.lo gdl.lo dll.lo \ + opt.lo tio.lo tio_get.lo tio_put.lo fio.lo pio.lo sio.lo \ + alg_search.lo alg_sort.lo time.lo misc.lo assert.lo main.lo \ + stdio.lo libqsecmn_la_OBJECTS = $(am_libqsecmn_la_OBJECTS) libqsecmn_la_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ @@ -265,7 +266,7 @@ lib_LTLIBRARIES = libqsecmn.la $(am__append_1) libqsecmn_la_SOURCES = \ syscall.h mem.h \ mem.c xma.c fma.c chr.c chr_cnv.c rex.c \ - str_bas.c str_cnv.c str_cmp.c str_cpy.c str_dyn.c str_fcpy.c \ + str_bas.c str_chr.c str_cnv.c str_cmp.c str_cpy.c str_dyn.c str_fcpy.c \ str_pbrk.c str_put.c str_spn.c str_utl.c \ lda.c oht.c htb.c rbt.c sll.c gdl.c dll.c opt.c \ tio.c tio_get.c tio_put.c \ @@ -385,6 +386,7 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sll.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/stdio.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/str_bas.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/str_chr.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/str_cmp.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/str_cnv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/str_cpy.Plo@am__quote@ diff --git a/qse/lib/cmn/str_bas.c b/qse/lib/cmn/str_bas.c index 59813698..ad2a5c2c 100644 --- a/qse/lib/cmn/str_bas.c +++ b/qse/lib/cmn/str_bas.c @@ -1,5 +1,5 @@ /* - * $Id: str_bas.c 413 2011-03-25 04:36:43Z hyunghwan.chung $ + * $Id: str_bas.c 416 2011-03-27 05:04:24Z hyunghwan.chung $ * Copyright 2006-2009 Chung, Hyung-Hwan. This file is part of QSE. @@ -401,65 +401,6 @@ qse_char_t* qse_strxnrstr ( return QSE_NULL; } -qse_mchar_t* qse_mbschr (const qse_mchar_t* str, qse_mcint_t c) -{ - while (*str != QSE_MT('\0')) - { - if (*str == c) return (qse_mchar_t*)str; - str++; - } - return QSE_NULL; -} - -qse_wchar_t* qse_wcschr (const qse_wchar_t* str, qse_wcint_t c) -{ - while (*str != QSE_WT('\0')) - { - if (*str == c) return (qse_wchar_t*)str; - str++; - } - return QSE_NULL; -} - -qse_char_t* qse_strxchr (const qse_char_t* str, qse_size_t len, qse_cint_t c) -{ - const qse_char_t* end = str + len; - - while (str < end) - { - if (*str == c) return (qse_char_t*)str; - str++; - } - - return QSE_NULL; -} - -qse_char_t* qse_strrchr (const qse_char_t* str, qse_cint_t c) -{ - const qse_char_t* end = str; - - while (*end != QSE_T('\0')) end++; - - while (end > str) - { - if (*--end == c) return (qse_char_t*)end; - } - - return QSE_NULL; -} - -qse_char_t* qse_strxrchr (const qse_char_t* str, qse_size_t len, qse_cint_t c) -{ - const qse_char_t* end = str + len; - - while (end > str) - { - if (*--end == c) return (qse_char_t*)end; - } - - return QSE_NULL; -} - const qse_char_t* qse_strxword ( const qse_char_t* str, qse_size_t len, const qse_char_t* word) { diff --git a/qse/lib/cmn/str_chr.c b/qse/lib/cmn/str_chr.c new file mode 100644 index 00000000..09b94263 --- /dev/null +++ b/qse/lib/cmn/str_chr.c @@ -0,0 +1,121 @@ +/* + * $Id$ + * + Copyright 2006-2009 Chung, Hyung-Hwan. + This file is part of QSE. + + QSE is free software: you can redistribute it and/or modify + it under the terms of the GNU Lesser General Public License as + published by the Free Software Foundation, either version 3 of + the License, or (at your option) any later version. + + QSE is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with QSE. If not, see . + */ + +#include + +qse_mchar_t* qse_mbschr (const qse_mchar_t* str, qse_mcint_t c) +{ + while (*str != QSE_MT('\0')) + { + if (*str == c) return (qse_mchar_t*)str; + str++; + } + return QSE_NULL; +} + +qse_mchar_t* qse_mbsxchr (const qse_mchar_t* str, qse_size_t len, qse_mcint_t c) +{ + const qse_mchar_t* end = str + len; + + while (str < end) + { + if (*str == c) return (qse_mchar_t*)str; + str++; + } + + return QSE_NULL; +} + +qse_mchar_t* qse_mbsrchr (const qse_mchar_t* str, qse_mcint_t c) +{ + const qse_mchar_t* end = str; + + while (*end != QSE_MT('\0')) end++; + + while (end > str) + { + if (*--end == c) return (qse_mchar_t*)end; + } + + return QSE_NULL; +} + +qse_mchar_t* qse_mbsxrchr (const qse_mchar_t* str, qse_size_t len, qse_mcint_t c) +{ + const qse_mchar_t* end = str + len; + + while (end > str) + { + if (*--end == c) return (qse_mchar_t*)end; + } + + return QSE_NULL; +} + +qse_wchar_t* qse_wcschr (const qse_wchar_t* str, qse_wcint_t c) +{ + while (*str != QSE_WT('\0')) + { + if (*str == c) return (qse_wchar_t*)str; + str++; + } + return QSE_NULL; +} + +qse_wchar_t* qse_wcsxchr (const qse_wchar_t* str, qse_size_t len, qse_wcint_t c) +{ + const qse_wchar_t* end = str + len; + + while (str < end) + { + if (*str == c) return (qse_wchar_t*)str; + str++; + } + + return QSE_NULL; +} + +qse_wchar_t* qse_wcsrchr (const qse_wchar_t* str, qse_wcint_t c) +{ + const qse_wchar_t* end = str; + + while (*end != QSE_MT('\0')) end++; + + while (end > str) + { + if (*--end == c) return (qse_wchar_t*)end; + } + + return QSE_NULL; +} + +qse_wchar_t* qse_wcsxrchr (const qse_wchar_t* str, qse_size_t len, qse_wcint_t c) +{ + const qse_wchar_t* end = str + len; + + while (end > str) + { + if (*--end == c) return (qse_wchar_t*)end; + } + + return QSE_NULL; +} + +