diff options
author | Arnold D. Robbins <arnold@skeeve.com> | 2018-09-21 13:17:11 +0300 |
---|---|---|
committer | Arnold D. Robbins <arnold@skeeve.com> | 2018-09-21 13:17:11 +0300 |
commit | e1be82e01980281819732b2c7012f6d331267cfd (patch) | |
tree | a3910d89104c59099f48ff36fbba3336cf564070 /re.c | |
parent | dfa06e8677737ca794f9505aac71d67679979c6d (diff) | |
parent | b1d75cf79c57071f55fcb6100a07d8cd706e890f (diff) | |
download | egawk-e1be82e01980281819732b2c7012f6d331267cfd.tar.gz egawk-e1be82e01980281819732b2c7012f6d331267cfd.tar.bz2 egawk-e1be82e01980281819732b2c7012f6d331267cfd.zip |
Merge branch 'master' into feature/fix-comments
Diffstat (limited to 're.c')
-rw-r--r-- | re.c | 8 |
1 files changed, 7 insertions, 1 deletions
@@ -112,6 +112,12 @@ make_regexp(const char *s, size_t len, bool ignorecase, bool dfa, bool canfatal) (*src == '\\')) { c = *++src; switch (c) { + case '\0': /* \\ before \0, either dynamic data or real end of string */ + if (src >= s + len) + *dest++ = '\\'; // at end of string, will fatal below + else + fatal(_("invalid NUL byte in dynamic regexp")); + break; case 'a': case 'b': case 'f': @@ -241,7 +247,7 @@ make_regexp(const char *s, size_t len, bool ignorecase, bool dfa, bool canfatal) error("%s: /%s/", rerr, buf); return NULL; } - fatal("%s: /%s/", rerr, buf); + fatal("invalid regexp: %s: /%s/", rerr, buf); } /* gack. this must be done *after* re_compile_pattern */ |