Fix invalid single character repetition issues in JIT.
This commit is contained in:
parent
3d80cf5a25
commit
a5389db88d
|
@ -1,6 +1,13 @@
|
||||||
Change Log for PCRE2
|
Change Log for PCRE2
|
||||||
--------------------
|
--------------------
|
||||||
|
|
||||||
|
Version 10.38-RC1 xx-xxx-2021
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
1. Fix invalid single character repetition issues in JIT when the repetition
|
||||||
|
is inside a capturing bracket and the bracket is preceeded by character
|
||||||
|
literals.
|
||||||
|
|
||||||
|
|
||||||
Version 10.37 26-May-2021
|
Version 10.37 26-May-2021
|
||||||
-------------------------
|
-------------------------
|
||||||
|
|
|
@ -1236,15 +1236,16 @@ start:
|
||||||
|
|
||||||
return: current number of iterators enhanced with fast fail
|
return: current number of iterators enhanced with fast fail
|
||||||
*/
|
*/
|
||||||
static int detect_early_fail(compiler_common *common, PCRE2_SPTR cc, int *private_data_start, sljit_s32 depth, int start)
|
static int detect_early_fail(compiler_common *common, PCRE2_SPTR cc, int *private_data_start,
|
||||||
|
sljit_s32 depth, int start, BOOL fast_forward_allowed)
|
||||||
{
|
{
|
||||||
PCRE2_SPTR begin = cc;
|
PCRE2_SPTR begin = cc;
|
||||||
PCRE2_SPTR next_alt;
|
PCRE2_SPTR next_alt;
|
||||||
PCRE2_SPTR end;
|
PCRE2_SPTR end;
|
||||||
PCRE2_SPTR accelerated_start;
|
PCRE2_SPTR accelerated_start;
|
||||||
|
BOOL prev_fast_forward_allowed;
|
||||||
int result = 0;
|
int result = 0;
|
||||||
int count;
|
int count;
|
||||||
BOOL fast_forward_allowed = TRUE;
|
|
||||||
|
|
||||||
SLJIT_ASSERT(*cc == OP_ONCE || *cc == OP_BRA || *cc == OP_CBRA);
|
SLJIT_ASSERT(*cc == OP_ONCE || *cc == OP_BRA || *cc == OP_CBRA);
|
||||||
SLJIT_ASSERT(*cc != OP_CBRA || common->optimized_cbracket[GET2(cc, 1 + LINK_SIZE)] != 0);
|
SLJIT_ASSERT(*cc != OP_CBRA || common->optimized_cbracket[GET2(cc, 1 + LINK_SIZE)] != 0);
|
||||||
|
@ -1476,6 +1477,7 @@ do
|
||||||
case OP_CBRA:
|
case OP_CBRA:
|
||||||
end = cc + GET(cc, 1);
|
end = cc + GET(cc, 1);
|
||||||
|
|
||||||
|
prev_fast_forward_allowed = fast_forward_allowed;
|
||||||
fast_forward_allowed = FALSE;
|
fast_forward_allowed = FALSE;
|
||||||
if (depth >= 4)
|
if (depth >= 4)
|
||||||
break;
|
break;
|
||||||
|
@ -1484,7 +1486,7 @@ do
|
||||||
if (*end != OP_KET || (*cc == OP_CBRA && common->optimized_cbracket[GET2(cc, 1 + LINK_SIZE)] == 0))
|
if (*end != OP_KET || (*cc == OP_CBRA && common->optimized_cbracket[GET2(cc, 1 + LINK_SIZE)] == 0))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
count = detect_early_fail(common, cc, private_data_start, depth + 1, count);
|
count = detect_early_fail(common, cc, private_data_start, depth + 1, count, prev_fast_forward_allowed);
|
||||||
|
|
||||||
if (PRIVATE_DATA(cc) != 0)
|
if (PRIVATE_DATA(cc) != 0)
|
||||||
common->private_data_ptrs[begin - common->start] = 1;
|
common->private_data_ptrs[begin - common->start] = 1;
|
||||||
|
@ -13657,7 +13659,7 @@ memset(common->private_data_ptrs, 0, total_length * sizeof(sljit_s32));
|
||||||
private_data_size = common->cbra_ptr + (re->top_bracket + 1) * sizeof(sljit_sw);
|
private_data_size = common->cbra_ptr + (re->top_bracket + 1) * sizeof(sljit_sw);
|
||||||
|
|
||||||
if ((re->overall_options & PCRE2_ANCHORED) == 0 && (re->overall_options & PCRE2_NO_START_OPTIMIZE) == 0 && !common->has_skip_in_assert_back)
|
if ((re->overall_options & PCRE2_ANCHORED) == 0 && (re->overall_options & PCRE2_NO_START_OPTIMIZE) == 0 && !common->has_skip_in_assert_back)
|
||||||
detect_early_fail(common, common->start, &private_data_size, 0, 0);
|
detect_early_fail(common, common->start, &private_data_size, 0, 0, TRUE);
|
||||||
|
|
||||||
set_private_data_ptrs(common, &private_data_size, ccend);
|
set_private_data_ptrs(common, &private_data_size, ccend);
|
||||||
|
|
||||||
|
|
|
@ -351,6 +351,7 @@ static struct regression_test_case regression_test_cases[] = {
|
||||||
{ MU, A, 0, 0, ".[ab]*a", "xxa" },
|
{ MU, A, 0, 0, ".[ab]*a", "xxa" },
|
||||||
{ MU, A, 0, 0, ".[ab]?.", "xx" },
|
{ MU, A, 0, 0, ".[ab]?.", "xx" },
|
||||||
{ MU, A, 0, 0, "_[ab]+_*a", "_aa" },
|
{ MU, A, 0, 0, "_[ab]+_*a", "_aa" },
|
||||||
|
{ MU, A, 0, 0, "#(A+)#\\d+", "#A#A#0" },
|
||||||
|
|
||||||
/* Bracket repeats with limit. */
|
/* Bracket repeats with limit. */
|
||||||
{ MU, A, 0, 0, "(?:(ab){2}){5}M", "abababababababababababM" },
|
{ MU, A, 0, 0, "(?:(ab){2}){5}M", "abababababababababababM" },
|
||||||
|
|
Loading…
Reference in New Issue