Fix handling of reg->dmin in Regex matching
This commit is contained in:
parent
45631622aa
commit
33e5b47c16
10
regexec.c
10
regexec.c
@ -4920,12 +4920,17 @@ forward_search_range(regex_t* reg, const UChar* str, const UChar* end, UChar* s,
|
|||||||
UChar* range, UChar** low, UChar** high, UChar** low_prev)
|
UChar* range, UChar** low, UChar** high, UChar** low_prev)
|
||||||
{
|
{
|
||||||
UChar *p, *pprev = (UChar* )NULL;
|
UChar *p, *pprev = (UChar* )NULL;
|
||||||
|
size_t input_len = end - str;
|
||||||
|
|
||||||
#ifdef ONIG_DEBUG_SEARCH
|
#ifdef ONIG_DEBUG_SEARCH
|
||||||
fprintf(stderr, "forward_search_range: str: %"PRIuPTR" (%p), end: %"PRIuPTR" (%p), s: %"PRIuPTR" (%p), range: %"PRIuPTR" (%p)\n",
|
fprintf(stderr, "forward_search_range: str: %"PRIuPTR" (%p), end: %"PRIuPTR" (%p), s: %"PRIuPTR" (%p), range: %"PRIuPTR" (%p)\n",
|
||||||
(uintptr_t )str, str, (uintptr_t )end, end, (uintptr_t )s, s, (uintptr_t )range, range);
|
(uintptr_t )str, str, (uintptr_t )end, end, (uintptr_t )s, s, (uintptr_t )range, range);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if (reg->dmin > input_len) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
p = s;
|
p = s;
|
||||||
if (reg->dmin > 0) {
|
if (reg->dmin > 0) {
|
||||||
if (ONIGENC_IS_SINGLEBYTE(reg->enc)) {
|
if (ONIGENC_IS_SINGLEBYTE(reg->enc)) {
|
||||||
@ -5062,6 +5067,11 @@ backward_search_range(regex_t* reg, const UChar* str, const UChar* end,
|
|||||||
UChar** low, UChar** high)
|
UChar** low, UChar** high)
|
||||||
{
|
{
|
||||||
UChar *p;
|
UChar *p;
|
||||||
|
size_t input_len = end - str;
|
||||||
|
|
||||||
|
if (reg->dmin > input_len) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
range += reg->dmin;
|
range += reg->dmin;
|
||||||
p = s;
|
p = s;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user