X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Frpmatch.c;h=826bc4c5e5244970bbbae96c273dabd2030bd5a9;hb=1146b210ba48607a5a29ea516a5cda3d5afa6542;hp=3a439d7e318153128b311912c2850d83f16f3877;hpb=ee369d4be4c24ee5645d99c33bb6340ea8173a77;p=gnulib.git diff --git a/lib/rpmatch.c b/lib/rpmatch.c index 3a439d7e3..826bc4c5e 100644 --- a/lib/rpmatch.c +++ b/lib/rpmatch.c @@ -1,11 +1,13 @@ /* Determine whether string value is affirmation or negative response according to current locale's data. - Copyright (C) 1996, 1998 Free Software Foundation, Inc. - This program is free software; you can redistribute it and/or modify + Copyright (C) 1996, 1998, 2000, 2002, 2003, 2006 Free Software + Foundation, Inc. + + 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,40 +15,23 @@ 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ - -#if HAVE_CONFIG_H -# include -#endif + along with this program. If not, see . */ -#if STDC_HEADERS || _LIBC -# include -# include -#else -# ifndef NULL -# define NULL 0 -# endif -#endif +#include -#include -#include +#include +#include #if ENABLE_NLS -# include -# define _(Text) gettext (Text) -#else -# define _(Text) Text -#endif +# include +# include +# include +# include "gettext.h" +# define _(msgid) gettext (msgid) static int -try (response, pattern, match, nomatch, lastp, re) - const char *response; - const char *pattern; - const int match; - const int nomatch; - const char **lastp; - regex_t *re; +try (const char *response, const char *pattern, const int match, + const int nomatch, const char **lastp, regex_t *re) { if (pattern != *lastp) { @@ -66,12 +51,13 @@ try (response, pattern, match, nomatch, lastp, re) /* See if the regular expression matches RESPONSE. */ return regexec (re, response, 0, NULL, 0) == 0 ? match : nomatch; } +#endif int -rpmatch (response) - const char *response; +rpmatch (const char *response) { +#if ENABLE_NLS /* Match against one of the response patterns, compiling the pattern first if necessary. */ @@ -84,4 +70,9 @@ rpmatch (response) &yesexpr, &yesre)) ? result : try (response, _("^[nN]"), 0, -1, &noexpr, &nore)); +#else + /* Test against "^[yY]" and "^[nN]", hardcoded to avoid requiring regex */ + return (*response == 'y' || *response == 'Y' ? 1 + : *response == 'n' || *response == 'N' ? 0 : -1); +#endif }