]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 8.2.2121: internal error when using \ze before \zs in a pattern v8.2.2121
authorBram Moolenaar <Bram@vim.org>
Wed, 9 Dec 2020 15:36:04 +0000 (16:36 +0100)
committerBram Moolenaar <Bram@vim.org>
Wed, 9 Dec 2020 15:36:04 +0000 (16:36 +0100)
Problem:    Internal error when using \ze before \zs in a pattern.
Solution:   Check the end is never before the start. (closes #7442)

src/regexp_bt.c
src/regexp_nfa.c
src/testdir/test_regexp_latin.vim
src/version.c

index 03b07a167953538dcdae10bd1fee829c010ca78c..476f34ef4027680e9bae61616aa512c75405bf71 100644 (file)
@@ -4805,6 +4805,23 @@ theend:
     if (backpos.ga_maxlen > BACKPOS_INITIAL)
        ga_clear(&backpos);
 
+    // Make sure the end is never before the start.  Can happen when \zs and
+    // \ze are used.
+    if (REG_MULTI)
+    {
+       lpos_T *start = &rex.reg_mmatch->startpos[0];
+       lpos_T *end = &rex.reg_mmatch->endpos[0];
+
+       if (end->lnum < start->lnum
+                       || (end->lnum == start->lnum && end->col < start->col))
+           rex.reg_mmatch->endpos[0] = rex.reg_mmatch->startpos[0];
+    }
+    else
+    {
+       if (rex.reg_match->endp[0] < rex.reg_match->startp[0])
+           rex.reg_match->endp[0] = rex.reg_match->startp[0];
+    }
+
     return retval;
 }
 
index c75c575fd4d4f22c4dc12cf2d0b18cea57960d3c..da80ee92163148d273eca820029db85be8d043fe 100644 (file)
@@ -7225,6 +7225,23 @@ nfa_regexec_both(
 #endif
 
 theend:
+    // Make sure the end is never before the start.  Can happen when \zs and
+    // \ze are used.
+    if (REG_MULTI)
+    {
+       lpos_T *start = &rex.reg_mmatch->startpos[0];
+       lpos_T *end = &rex.reg_mmatch->endpos[0];
+
+       if (end->lnum < start->lnum
+                       || (end->lnum == start->lnum && end->col < start->col))
+           rex.reg_mmatch->endpos[0] = rex.reg_mmatch->startpos[0];
+    }
+    else
+    {
+       if (rex.reg_match->endp[0] < rex.reg_match->startp[0])
+           rex.reg_match->endp[0] = rex.reg_match->startp[0];
+    }
+
     return retval;
 }
 
index d1885ab5ce94e6c32eeb22f803ccc6e1b0cbb8b6..0b0024453d2745649c190ccc98c6eaf5f826f7d9 100644 (file)
@@ -911,6 +911,13 @@ func Test_start_end_of_buffer_match()
   bwipe!
 endfunc
 
+func Test_ze_before_zs()
+  call assert_equal('', matchstr(' ', '\%#=1\ze \zs'))
+  call assert_equal('', matchstr(' ', '\%#=2\ze \zs'))
+  call assert_equal(repeat([''], 10), matchlist(' ', '\%#=1\ze \zs'))
+  call assert_equal(repeat([''], 10), matchlist(' ', '\%#=2\ze \zs'))
+endfunc
+
 " Check for detecting error
 func Test_regexp_error()
   call assert_fails("call matchlist('x x', '\\%#=1 \\zs*')", 'E888:')
index 9d09c07a005b6f27ec513b80d426c6fa2771136c..9bb587dff6e4555245e59820a155f11fe47b97c6 100644 (file)
@@ -750,6 +750,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    2121,
 /**/
     2120,
 /**/