From 32da3a01ed8b711d5586a52186eb540fbeda0ae1 Mon Sep 17 00:00:00 2001 From: Jim Meyering Date: Tue, 8 Feb 1994 04:01:10 +0000 Subject: [PATCH] *** empty log message *** --- regex.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/regex.c b/regex.c index e71961594..532d75330 100644 --- a/regex.c +++ b/regex.c @@ -3324,6 +3324,10 @@ re_match_2 (bufp, string1, size1, string2, size2, pos, regs, stop) unsigned char *p = bufp->buffer; register unsigned char *pend = p + bufp->used; + /* Mark the opcode just after a start_memory, so we can test for an + empty subpattern when we get to the stop_memory. */ + unsigned char *just_past_start_mem = 0; + /* We use this to map every character in the string. */ char *translate = bufp->translate; @@ -3804,6 +3808,7 @@ re_match_2 (bufp, string1, size1, string2, size2, pos, regs, stop) /* Move past the register number and inner group count. */ p += 2; + just_past_start_mem = p; break; @@ -3868,7 +3873,7 @@ re_match_2 (bufp, string1, size1, string2, size2, pos, regs, stop) information for this group that we had before trying this last match. */ if ((!MATCHED_SOMETHING (reg_info[*p]) - || (re_opcode_t) p[-3] == start_memory) + || just_past_start_mem == p - 1) && (p + 2) < pend) { boolean is_a_jump_n = false; -- 2.11.0