From 5be9ffed258cc3d662427389501cab9914d694b9 Mon Sep 17 00:00:00 2001 From: "Vladimir.Marek" Date: Mon, 6 May 2013 17:16:01 +0200 Subject: [PATCH] [PATCH 3/4] strsep: check for availability (Solaris support) --- 91/ee9d10fc19640872e3c9531c13be30792d5fb5 | 248 ++++++++++++++++++++++ 1 file changed, 248 insertions(+) create mode 100644 91/ee9d10fc19640872e3c9531c13be30792d5fb5 diff --git a/91/ee9d10fc19640872e3c9531c13be30792d5fb5 b/91/ee9d10fc19640872e3c9531c13be30792d5fb5 new file mode 100644 index 000000000..20fdd3971 --- /dev/null +++ b/91/ee9d10fc19640872e3c9531c13be30792d5fb5 @@ -0,0 +1,248 @@ +Return-Path: +X-Original-To: notmuch@notmuchmail.org +Delivered-To: notmuch@notmuchmail.org +Received: from localhost (localhost [127.0.0.1]) + by olra.theworths.org (Postfix) with ESMTP id ECBE6429E29 + for ; Mon, 6 May 2013 08:16:55 -0700 (PDT) +X-Virus-Scanned: Debian amavisd-new at olra.theworths.org +X-Spam-Flag: NO +X-Spam-Score: -2.299 +X-Spam-Level: +X-Spam-Status: No, score=-2.299 tagged_above=-999 required=5 + tests=[RCVD_IN_DNSWL_MED=-2.3, UNPARSEABLE_RELAY=0.001] + autolearn=disabled +Received: from olra.theworths.org ([127.0.0.1]) + by localhost (olra.theworths.org [127.0.0.1]) (amavisd-new, port 10024) + with ESMTP id ztnn-hQRPrym for ; + Mon, 6 May 2013 08:16:52 -0700 (PDT) +Received: from userp1040.oracle.com (userp1040.oracle.com [156.151.31.81]) + (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) + (No client certificate requested) + by olra.theworths.org (Postfix) with ESMTPS id 71CA5431E82 + for ; Mon, 6 May 2013 08:16:36 -0700 (PDT) +Received: from acsinet21.oracle.com (acsinet21.oracle.com [141.146.126.237]) + by userp1040.oracle.com (Sentrion-MTA-4.3.1/Sentrion-MTA-4.3.1) with + ESMTP id r46FGRrf001034 + (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=OK); + Mon, 6 May 2013 15:16:28 GMT +Received: from userz7021.oracle.com (userz7021.oracle.com [156.151.31.85]) + by acsinet21.oracle.com (8.14.4+Sun/8.14.4) with ESMTP id + r46FGRL4027370 + (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=FAIL); + Mon, 6 May 2013 15:16:28 GMT +Received: from abhmt119.oracle.com (abhmt119.oracle.com [141.146.116.71]) + by userz7021.oracle.com (8.14.4+Sun/8.14.4) with ESMTP id + r46FGRxt027181; Mon, 6 May 2013 15:16:27 GMT +Received: from vi64-x3-2e-prg06.cz.oracle.com (/10.163.102.127) + by default (Oracle Beehive Gateway v4.0) + with ESMTP ; Mon, 06 May 2013 08:16:26 -0700 +From: Vladimir.Marek@oracle.com +To: notmuch@notmuchmail.org +Subject: [PATCH 3/4] strsep: check for availability (Solaris support) +Date: Mon, 6 May 2013 17:16:01 +0200 +Message-Id: <1367853362-11846-4-git-send-email-Vladimir.Marek@oracle.com> +X-Mailer: git-send-email 1.7.9.2 +In-Reply-To: <1367853362-11846-1-git-send-email-Vladimir.Marek@oracle.com> +References: <1367853362-11846-1-git-send-email-Vladimir.Marek@oracle.com> +X-Source-IP: acsinet21.oracle.com [141.146.126.237] +Cc: Vladimir Marek +X-BeenThere: notmuch@notmuchmail.org +X-Mailman-Version: 2.1.13 +Precedence: list +List-Id: "Use and development of the notmuch mail system." + +List-Unsubscribe: , + +List-Archive: +List-Post: +List-Help: +List-Subscribe: , + +X-List-Received-Date: Mon, 06 May 2013 15:16:56 -0000 + +From: Blake Jones + +Solaris does not ship a version of the strsep() function. This change +adds a check to "configure" to see whether notmuch needs to provide its +own implementation, and if so, it uses the new version in +"compat/strsep.c" (which was copied from Mutt, and apparently before +that from glibc). + +Signed-off-by: Vladimir Marek +--- + compat/Makefile.local | 4 +++ + compat/compat.h | 4 +++ + compat/have_strsep.c | 11 +++++++++ + compat/strsep.c | 65 +++++++++++++++++++++++++++++++++++++++++++++++++ + configure | 17 +++++++++++++ + 5 files changed, 101 insertions(+) + create mode 100644 compat/have_strsep.c + create mode 100644 compat/strsep.c + +diff --git a/compat/Makefile.local b/compat/Makefile.local +index 13f16cd..2c4f65f 100644 +--- a/compat/Makefile.local ++++ b/compat/Makefile.local +@@ -13,4 +13,8 @@ ifneq ($(HAVE_STRCASESTR),1) + notmuch_compat_srcs += $(dir)/strcasestr.c + endif + ++ifneq ($(HAVE_STRSEP),1) ++notmuch_compat_srcs += $(dir)/strsep.c ++endif ++ + SRCS := $(SRCS) $(notmuch_compat_srcs) +diff --git a/compat/compat.h b/compat/compat.h +index 0c4ac66..ae762c3 100644 +--- a/compat/compat.h ++++ b/compat/compat.h +@@ -53,6 +53,10 @@ getdelim (char **lineptr, size_t *n, int delimiter, FILE *fp); + char* strcasestr(const char *haystack, const char *needle); + #endif /* !HAVE_STRCASESTR */ + ++#if !HAVE_STRSEP ++char *strsep(char **stringp, const char *delim); ++#endif /* !HAVE_STRSEP */ ++ + /* Silence gcc warnings about unused results. These warnings exist + * for a reason; any use of this needs to be justified. */ + #ifdef __GNUC__ +diff --git a/compat/have_strsep.c b/compat/have_strsep.c +new file mode 100644 +index 0000000..2abab81 +--- /dev/null ++++ b/compat/have_strsep.c +@@ -0,0 +1,11 @@ ++#define _GNU_SOURCE ++#include ++ ++int main() ++{ ++ char *found; ++ char **stringp; ++ const char *delim; ++ ++ found = strsep(stringp, delim); ++} +diff --git a/compat/strsep.c b/compat/strsep.c +new file mode 100644 +index 0000000..78ab9e7 +--- /dev/null ++++ b/compat/strsep.c +@@ -0,0 +1,65 @@ ++/* Copyright (C) 1992, 93, 96, 97, 98, 99, 2004 Free Software Foundation, Inc. ++ This file is part of the GNU C Library. ++ ++ The GNU C Library 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 2.1 of the License, or (at your option) any later version. ++ ++ The GNU C Library 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 the GNU C Library; if not, write to the Free ++ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA ++ 02111-1307 USA. */ ++ ++#include ++ ++/* Taken from glibc 2.6.1 */ ++ ++char *strsep (char **stringp, const char *delim) ++{ ++ char *begin, *end; ++ ++ begin = *stringp; ++ if (begin == NULL) ++ return NULL; ++ ++ /* A frequent case is when the delimiter string contains only one ++ character. Here we don't need to call the expensive `strpbrk' ++ function and instead work using `strchr'. */ ++ if (delim[0] == '\0' || delim[1] == '\0') ++ { ++ char ch = delim[0]; ++ ++ if (ch == '\0') ++ end = NULL; ++ else ++ { ++ if (*begin == ch) ++ end = begin; ++ else if (*begin == '\0') ++ end = NULL; ++ else ++ end = strchr (begin + 1, ch); ++ } ++ } ++ else ++ /* Find the end of the token. */ ++ end = strpbrk (begin, delim); ++ ++ if (end) ++ { ++ /* Terminate the token and set *STRINGP past NUL character. */ ++ *end++ = '\0'; ++ *stringp = end; ++ } ++ else ++ /* No more delimiters; this is the last token. */ ++ *stringp = NULL; ++ ++ return begin; ++} +diff --git a/configure b/configure +index 99ec71a..5243cac 100755 +--- a/configure ++++ b/configure +@@ -517,6 +517,17 @@ else + fi + rm -f compat/have_strcasestr + ++printf "Checking for strsep... " ++if ${CC} -o compat/have_strsep "$srcdir"/compat/have_strsep.c > /dev/null 2>&1 ++then ++ printf "Yes.\n" ++ have_strsep="1" ++else ++ printf "No (will use our own instead).\n" ++ have_strsep="0" ++fi ++rm -f compat/have_strsep ++ + printf "Checking for standard version of getpwuid_r... " + if ${CC} -o compat/check_getpwuid "$srcdir"/compat/check_getpwuid.c > /dev/null 2>&1 + then +@@ -698,6 +709,10 @@ HAVE_GETLINE = ${have_getline} + # build its own version) + HAVE_STRCASESTR = ${have_strcasestr} + ++# Whether the strsep function is available (if not, then notmuch will ++# build its own version) ++HAVE_STRSEP = ${have_strsep} ++ + # Whether the getpwuid_r function is standards-compliant + # (if not, then notmuch will #define _POSIX_PTHREAD_SEMANTICS + # to enable the standards-compliant version -- needed for Solaris) +@@ -754,12 +769,14 @@ CONFIGURE_CFLAGS = -DHAVE_GETLINE=\$(HAVE_GETLINE) \$(GMIME_CFLAGS) \\ + \$(TALLOC_CFLAGS) -DHAVE_VALGRIND=\$(HAVE_VALGRIND) \\ + \$(VALGRIND_CFLAGS) \\ + -DHAVE_STRCASESTR=\$(HAVE_STRCASESTR) \\ ++ -DHAVE_STRSEP=\$(HAVE_STRSEP) \\ + -DSTD_GETPWUID=\$(STD_GETPWUID) \\ + -DSTD_ASCTIME=\$(STD_ASCTIME) + CONFIGURE_CXXFLAGS = -DHAVE_GETLINE=\$(HAVE_GETLINE) \$(GMIME_CFLAGS) \\ + \$(TALLOC_CFLAGS) -DHAVE_VALGRIND=\$(HAVE_VALGRIND) \\ + \$(VALGRIND_CFLAGS) \$(XAPIAN_CXXFLAGS) \\ + -DHAVE_STRCASESTR=\$(HAVE_STRCASESTR) \\ ++ -DHAVE_STRSEP=\$(HAVE_STRSEP) \\ + -DSTD_GETPWUID=\$(STD_GETPWUID) \\ + -DSTD_ASCTIME=\$(STD_ASCTIME) + CONFIGURE_LDFLAGS = \$(GMIME_LDFLAGS) \$(TALLOC_LDFLAGS) \$(XAPIAN_LDFLAGS) +-- +1.7.9.2 + -- 2.26.2