diff options
author | Bram Moolenaar <Bram@vim.org> | 2020-12-09 16:36:04 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2020-12-09 16:36:04 +0100 |
commit | a7a691cc142439e266f4ceb1f208bb952b57aa71 (patch) | |
tree | ebe600566e203253e7f6f2502c3032c2608c32ec | |
parent | 730677a0dafe6f2e72888ef59f74f66f2d0a573e (diff) | |
download | vim-git-a7a691cc142439e266f4ceb1f208bb952b57aa71.tar.gz |
patch 8.2.2121: internal error when using \ze before \zs in a patternv8.2.2121
Problem: Internal error when using \ze before \zs in a pattern.
Solution: Check the end is never before the start. (closes #7442)
-rw-r--r-- | src/regexp_bt.c | 17 | ||||
-rw-r--r-- | src/regexp_nfa.c | 17 | ||||
-rw-r--r-- | src/testdir/test_regexp_latin.vim | 7 | ||||
-rw-r--r-- | src/version.c | 2 |
4 files changed, 43 insertions, 0 deletions
diff --git a/src/regexp_bt.c b/src/regexp_bt.c index 03b07a167..476f34ef4 100644 --- a/src/regexp_bt.c +++ b/src/regexp_bt.c @@ -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; } diff --git a/src/regexp_nfa.c b/src/regexp_nfa.c index c75c575fd..da80ee921 100644 --- a/src/regexp_nfa.c +++ b/src/regexp_nfa.c @@ -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; } diff --git a/src/testdir/test_regexp_latin.vim b/src/testdir/test_regexp_latin.vim index d1885ab5c..0b0024453 100644 --- a/src/testdir/test_regexp_latin.vim +++ b/src/testdir/test_regexp_latin.vim @@ -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:') diff --git a/src/version.c b/src/version.c index 9d09c07a0..9bb587dff 100644 --- a/src/version.c +++ b/src/version.c @@ -751,6 +751,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 2121, +/**/ 2120, /**/ 2119, |