pcre2/backport-Fix-incorrect-patch-in-c1306126.patch
xujing a29f481ca1 pcre2: sync patches from upstream to fix some bugs
(cherry picked from commit 82d5abb0f43f316d60eb45056565a6d02d68cb85)
2024-01-22 15:26:32 +08:00

98 lines
3.0 KiB
Diff

From 7fe586b892c9e0cbf3b21d57cfd8135e2311e45c Mon Sep 17 00:00:00 2001
From: Philip Hazel <Philip.Hazel@gmail.com>
Date: Mon, 20 Nov 2023 15:41:06 +0000
Subject: [PATCH] Fix incorrect patch in c1306126
Conflict:adapt context
Reference:https://github.com/PCRE2Project/pcre2/commit/7fe586b892c9e0cbf3b21d57cfd8135e2311e45c
---
src/pcre2_compile.c | 20 ++++++++++++++------
testdata/testinput2 | 2 ++
testdata/testoutput2 | 2 ++
3 files changed, 18 insertions(+), 6 deletions(-)
diff --git a/src/pcre2_compile.c b/src/pcre2_compile.c
index fdaf2ad..9e45580 100644
--- a/src/pcre2_compile.c
+++ b/src/pcre2_compile.c
@@ -2782,6 +2782,7 @@ uint32_t *previous_callout = NULL;
uint32_t *parsed_pattern = cb->parsed_pattern;
uint32_t *parsed_pattern_end = cb->parsed_pattern_end;
uint32_t *this_parsed_item = NULL;
+uint32_t *prev_parsed_item = NULL;
uint32_t meta_quantifier = 0;
uint32_t add_after_mark = 0;
uint32_t extra_options = cb->cx->extra_options;
@@ -2867,11 +2868,10 @@ while (ptr < ptrend)
uint32_t set, unset, *optset;
uint32_t terminator;
uint32_t prev_meta_quantifier;
- uint32_t *prev_parsed_item = this_parsed_item;
BOOL prev_okquantifier;
PCRE2_SPTR tempptr;
PCRE2_SIZE offset;
-
+
if (parsed_pattern >= parsed_pattern_end)
{
errorcode = ERR63; /* Internal error (parsed pattern overflow) */
@@ -2883,10 +2883,17 @@ while (ptr < ptrend)
errorcode = ERR19;
goto FAILED; /* Parentheses too deeply nested */
}
-
- /* Remember where this item started */
- this_parsed_item = parsed_pattern;
+ /* If the last time round this loop something was added, parsed_pattern will
+ no longer be equal to this_parsed_item. Remember where the previous item
+ started and reset for the next item. Note that sometimes round the loop,
+ nothing gets added (e.g. for ignored white space). */
+
+ if (this_parsed_item != parsed_pattern)
+ {
+ prev_parsed_item = this_parsed_item;
+ this_parsed_item = parsed_pattern;
+ }
/* Get next input character, save its position for callout handling. */
@@ -3440,7 +3447,8 @@ while (ptr < ptrend)
/* ---- Quantifier post-processing ---- */
- /* Check that a quantifier is allowed after the previous item. */
+ /* Check that a quantifier is allowed after the previous item. This
+ guarantees that there is a previous item. */
CHECK_QUANTIFIER:
if (!prev_okquantifier)
diff --git a/testdata/testinput2 b/testdata/testinput2
index ba292d8..da845c1 100644
--- a/testdata/testinput2
+++ b/testdata/testinput2
@@ -6051,4 +6051,6 @@ a)"xI
--
\[X]{-10}
+/A +/extended
+
# End of testinput2
diff --git a/testdata/testoutput2 b/testdata/testoutput2
index 888f06a..85de4ae 100644
--- a/testdata/testoutput2
+++ b/testdata/testoutput2
@@ -17932,6 +17932,8 @@ No match
\[X]{-10}
** Zero or negative repeat not allowed
+/A +/extended
+
# End of testinput2
Error -70: PCRE2_ERROR_BADDATA (unknown error number)
Error -62: bad serialized data
--
2.23.0