X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Frpmatch.c;h=7759d0ca7e964844604c7396d1497c3fbc03e889;hb=4b08703dc1d89681fcba8be35b7e7884b446b38f;hp=9cc51755d6b1cc35f39c2ead07fd295c992c1306;hpb=cf42d3e5e80be6bf7093a3ca9be0d04033eaf527;p=gnulib.git diff --git a/lib/rpmatch.c b/lib/rpmatch.c index 9cc51755d..7759d0ca7 100644 --- a/lib/rpmatch.c +++ b/lib/rpmatch.c @@ -1,6 +1,6 @@ /* Determine whether string value is affirmation or negative response according to current locale's data. - Copyright (C) 1996, 1998 Free Software Foundation, Inc. + Copyright (C) 1996, 1998, 2000, 2002, 2003 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 @@ -20,27 +20,21 @@ # include #endif +#include #if STDC_HEADERS || _LIBC -# include # include -#else -# ifndef NULL -# define NULL 0 -# endif #endif -#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 (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) { @@ -60,11 +54,13 @@ try (const char *response, const char *pattern, const int match, const int nomat /* See if the regular expression matches RESPONSE. */ return regexec (re, response, 0, NULL, 0) == 0 ? match : nomatch; } +#endif int rpmatch (const char *response) { +#if ENABLE_NLS /* Match against one of the response patterns, compiling the pattern first if necessary. */ @@ -77,4 +73,9 @@ rpmatch (const char *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 }