From ce86a05f3639f78dcbe10c3e72634a7502d04607 Mon Sep 17 00:00:00 2001 From: sin Date: Thu, 20 Nov 2014 23:43:08 +0000 Subject: [PATCH] Import strcasestr() from musl and remove -D_GNU_SOURCE --- Makefile | 1 + config.mk | 2 +- grep.c | 1 - libutil/strcasestr.c | 33 +++++++++++++++++++++++++++++++++ util.h | 3 +++ 5 files changed, 38 insertions(+), 2 deletions(-) create mode 100644 libutil/strcasestr.c diff --git a/Makefile b/Makefile index c8086f7..100632d 100644 --- a/Makefile +++ b/Makefile @@ -48,6 +48,7 @@ LIBUTILSRC =\ libutil/sha1.c\ libutil/sha256.c\ libutil/sha512.c\ + libutil/strcasestr.c\ libutil/strlcat.c\ libutil/strlcpy.c diff --git a/config.mk b/config.mk index fc608ee..a944970 100644 --- a/config.mk +++ b/config.mk @@ -10,6 +10,6 @@ LD = $(CC) AR = ar RANLIB = ranlib -CPPFLAGS = -D_DEFAULT_SOURCE -D_BSD_SOURCE -D_GNU_SOURCE +CPPFLAGS = -D_DEFAULT_SOURCE -D_BSD_SOURCE -D_XOPEN_SOURCE=700 CFLAGS = -std=c99 -Wall -pedantic LDFLAGS = -s diff --git a/grep.c b/grep.c index d74f2fc..1b89242 100644 --- a/grep.c +++ b/grep.c @@ -3,7 +3,6 @@ #include #include #include -#include #include #include "queue.h" diff --git a/libutil/strcasestr.c b/libutil/strcasestr.c new file mode 100644 index 0000000..47ef412 --- /dev/null +++ b/libutil/strcasestr.c @@ -0,0 +1,33 @@ +/* + * Copyright 2005-2014 Rich Felker, et al. + * + * Permission is hereby granted, free of charge, to any person obtaining + * a copy of this software and associated documentation files (the + * "Software"), to deal in the Software without restriction, including + * without limitation the rights to use, copy, modify, merge, publish, + * distribute, sublicense, and/or sell copies of the Software, and to + * permit persons to whom the Software is furnished to do so, subject to + * the following conditions: + * + * The above copyright notice and this permission notice shall be + * included in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. + * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY + * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, + * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE + * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +*/ +#include + +#include "../util.h" + +char * +strcasestr(const char *h, const char *n) +{ + size_t l = strlen(n); + for (; *h; h++) if (!strncasecmp(h, n, l)) return (char *)h; + return 0; +} diff --git a/util.h b/util.h index 2de6f3b..5fc2642 100644 --- a/util.h +++ b/util.h @@ -33,6 +33,9 @@ void weprintf(const char *, ...); double estrtod(const char *); long estrtol(const char *, int); +#undef strcasestr +char *strcasestr(const char *, const char *); + #undef strlcat size_t strlcat(char *, const char *, size_t); #undef strlcpy