From d09171fe28b0b29f90cdf3fe2ebe03c39365cddd Mon Sep 17 00:00:00 2001 From: Dmitry Mikhirev Date: Mon, 17 Nov 2014 19:31:51 +0300 Subject: handle some possible errors --- pcre.c | 33 +++++++++++++++++++++++++++++---- 1 file changed, 29 insertions(+), 4 deletions(-) diff --git a/pcre.c b/pcre.c index 10fe267..ab4a30e 100644 --- a/pcre.c +++ b/pcre.c @@ -33,9 +33,10 @@ char *match(const char *name, int argc, char **argv) char *pat = NULL; /* expanded pattern */ char *p; /* iteration pointer */ int co = 0; /* pattern compilation options */ + int b; /* PCRE configuration option value */ pcre *re; /* compiled regexp */ const char *err; /* compilation error */ - int erroffset; /* offset of pattern character whwre error occured */ + int erroffset; /* offset of pattern character where error occured */ char *str = NULL; /* expanded subject string */ int ncap = 0; /* number of captured substrings */ int ovec[MAX_CAP*3]; /* ovector */ @@ -58,7 +59,18 @@ char *match(const char *name, int argc, char **argv) co |= PCRE_DOTALL; break; case 'u': /* use Unicode properties */ - co |= PCRE_UCP; + pcre_config(PCRE_CONFIG_UNICODE_PROPERTIES, + &b); + if (b) { + co |= PCRE_UCP; + } else { + fprintf(stderr, "%s: PCRE library " + "does not support " + "Unicode properties, " + "`%c' option is " + "unavailable\n", + name, *p); + } break; case 'U': /* ungreedy quantifiers */ co |= PCRE_UNGREEDY; @@ -70,7 +82,17 @@ char *match(const char *name, int argc, char **argv) co |= PCRE_EXTRA; break; case '8': /* UTF-8 */ - co |= PCRE_UTF8; + pcre_config(PCRE_CONFIG_UTF8, &b); + if (b) { + co |= PCRE_UTF8; + } else { + fprintf(stderr, "%s: PCRE library " + "does not support " + "UTF-8, " + "`%c' option is " + "unavailable\n", + name, *p); + } break; default: /* unknown option */ fprintf(stderr, "%s: unknown option `%c'\n", @@ -95,9 +117,12 @@ char *match(const char *name, int argc, char **argv) str = gmk_expand(argv[1]); ncap = pcre_exec(re, NULL, str, strlen(str), 0, 0, ovec, MAX_CAP*3); pcre_free(re); + if (ncap < 0) { /* error occured */ + fprintf(stderr, "%s: pattern matching error: %d\n", name, ncap); + } end_match: - if (ncap) { /* set retstr to matched substring */ + if (ncap > 0) { /* set retstr to matched substring */ int len = ovec[1] - ovec[0]; retstr = gmk_alloc(len + 1); strncpy(retstr, str + ovec[0], len); -- cgit v1.2.3