From a877402c0f14eb9614576cc1b3579a5ca4b683ef Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Tue, 1 Oct 2002 09:26:03 +0000 Subject: [PATCH] Update. 2002-10-01 Isamu Hasegawa * posix/regex_internal.c (re_string_reconstruct): Reset the member LEN and STOP. * posix/regexec.c (re_search_stub): Remove incorrect condition of "range < 0". Round RANGE in case that it is too small. --- ChangeLog | 8 ++++++++ posix/regexec.c | 4 +++- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index 42a958ff97..7cf80879a5 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2002-10-01 Isamu Hasegawa + + * posix/regex_internal.c (re_string_reconstruct): Reset the member + LEN and STOP. + * posix/regexec.c (re_search_stub): Remove incorrect condition of + "range < 0". + Round RANGE in case that it is too small. + 2002-10-01 Roland McGrath * config.h.in (NO_HIDDEN): New #undef. diff --git a/posix/regexec.c b/posix/regexec.c index 8988c6633c..7e3a8320b1 100644 --- a/posix/regexec.c +++ b/posix/regexec.c @@ -357,10 +357,12 @@ re_search_stub (bufp, string, length, start, range, stop, regs, ret_len) int eflags = 0; /* Check for out-of-range. */ - if (BE (start < 0 || start > length || range < 0, 0)) + if (BE (start < 0 || start > length, 0)) return -1; if (BE (start + range > length, 0)) range = length - start; + else if (BE (start + range < 0, 0)) + range = -start; eflags |= (bufp->not_bol) ? REG_NOTBOL : 0; eflags |= (bufp->not_eol) ? REG_NOTEOL : 0; -- 2.11.4.GIT