Discard partial match when endanchored is set in the fuzzer, as it just gives
an immediate bad options return.
This commit is contained in:
parent
3f96e07e6b
commit
62e202f757
|
@ -42,7 +42,6 @@ bugs were never in fully released code, but are noted here for the record.
|
||||||
(g) Similarly refactor the way the variable length ovector is addressed for
|
(g) Similarly refactor the way the variable length ovector is addressed for
|
||||||
similar reasons. Fixes oss-fuzz issue 1465.
|
similar reasons. Fixes oss-fuzz issue 1465.
|
||||||
|
|
||||||
|
|
||||||
2. Now that pcre2_match() no longer uses recursive function calls (see above),
|
2. Now that pcre2_match() no longer uses recursive function calls (see above),
|
||||||
the "match limit recursion" value seems misnamed. It still exists, and limits
|
the "match limit recursion" value seems misnamed. It still exists, and limits
|
||||||
the depth of tree that is searched. To avoid future confusion, it has been
|
the depth of tree that is searched. To avoid future confusion, it has been
|
||||||
|
|
|
@ -85,7 +85,7 @@ r2 = rand();
|
||||||
and also that PCRE2_NO_UTF_CHECK is unset, as there is no guarantee that the
|
and also that PCRE2_NO_UTF_CHECK is unset, as there is no guarantee that the
|
||||||
input is UTF-8. Also unset PCRE2_NEVER_UTF and PCRE2_NEVER_UCP as there is no
|
input is UTF-8. Also unset PCRE2_NEVER_UTF and PCRE2_NEVER_UCP as there is no
|
||||||
reason to disallow UTF and UCP. Force PCRE2_NEVER_BACKSLASH_C to be set because
|
reason to disallow UTF and UCP. Force PCRE2_NEVER_BACKSLASH_C to be set because
|
||||||
\C in random patterns is highly likely to cause a crash. */
|
\C in random patterns is highly likely to cause a crash. */
|
||||||
|
|
||||||
compile_options =
|
compile_options =
|
||||||
((((uint32_t)r1 << 16) | ((uint32_t)r2 & 0xffff)) & ALLOWED_COMPILE_OPTIONS) |
|
((((uint32_t)r1 << 16) | ((uint32_t)r2 & 0xffff)) & ALLOWED_COMPILE_OPTIONS) |
|
||||||
|
@ -94,6 +94,12 @@ compile_options =
|
||||||
match_options =
|
match_options =
|
||||||
((((uint32_t)r1 << 16) | ((uint32_t)r2 & 0xffff)) & ALLOWED_MATCH_OPTIONS);
|
((((uint32_t)r1 << 16) | ((uint32_t)r2 & 0xffff)) & ALLOWED_MATCH_OPTIONS);
|
||||||
|
|
||||||
|
/* Discard partial matching if PCRE2_ENDANCHORED is set, because they are not
|
||||||
|
allowed together and just give an immediate error return. */
|
||||||
|
|
||||||
|
if (((compile_options|match_options) & PCRE2_ENDANCHORED) != 0)
|
||||||
|
match_options &= ~(PCRE2_PARTIAL_HARD|PCRE2_PARTIAL_SOFT);
|
||||||
|
|
||||||
/* Do the compile with and without the options, and after a successful compile,
|
/* Do the compile with and without the options, and after a successful compile,
|
||||||
likewise do the match with and without the options. */
|
likewise do the match with and without the options. */
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue