summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2022-09-08 12:17:06 +0100
committerBram Moolenaar <Bram@vim.org>2022-09-08 12:17:06 +0100
commit753aead960f163d0d3f8ce523ea523f2e0cec06d (patch)
treeb8095e475cf64797ad6c18be85388ab142750283
parentb0d12e63e8c763ce940dc4c162111fedde2507ef (diff)
downloadvim-git-753aead960f163d0d3f8ce523ea523f2e0cec06d.tar.gz
patch 9.0.0414: matchstr() still does not match column offsetv9.0.0414
Problem: matchstr() still does not match column offset when done after a text search. Solution: Only use the line number for a multi-line search. Fix the test. (closes #10938)
-rw-r--r--src/regexp_bt.c10
-rw-r--r--src/regexp_nfa.c14
-rw-r--r--src/testdir/test_regexp_latin.vim6
-rw-r--r--src/version.c2
4 files changed, 22 insertions, 10 deletions
diff --git a/src/regexp_bt.c b/src/regexp_bt.c
index e3e7a1801..520656798 100644
--- a/src/regexp_bt.c
+++ b/src/regexp_bt.c
@@ -3441,11 +3441,13 @@ regmatch(
case RE_VCOL:
{
win_T *wp = rex.reg_win == NULL ? curwin : rex.reg_win;
- linenr_T lnum = rex.reg_firstlnum + rex.lnum;
- long_u vcol = 0;
+ linenr_T lnum = REG_MULTI ? rex.reg_firstlnum + rex.lnum : 1;
+ long_u vcol;
- if (lnum >= 0 && lnum <= wp->w_buffer->b_ml.ml_line_count)
- vcol = (long_u)win_linetabsize(wp, lnum, rex.line,
+ if (REG_MULTI && (lnum <= 0
+ || lnum > wp->w_buffer->b_ml.ml_line_count))
+ lnum = 1;
+ vcol = (long_u)win_linetabsize(wp, lnum, rex.line,
(colnr_T)(rex.input - rex.line));
if (!re_num_cmp(vcol + 1, scan))
status = RA_NOMATCH;
diff --git a/src/regexp_nfa.c b/src/regexp_nfa.c
index b39848927..fc1a99339 100644
--- a/src/regexp_nfa.c
+++ b/src/regexp_nfa.c
@@ -6775,12 +6775,14 @@ nfa_regmatch(
}
if (!result)
{
- linenr_T lnum = rex.reg_firstlnum + rex.lnum;
- long_u vcol = 0;
-
- if (lnum >= 0
- && lnum <= wp->w_buffer->b_ml.ml_line_count)
- vcol = (long_u)win_linetabsize(wp, lnum,
+ linenr_T lnum = REG_MULTI
+ ? rex.reg_firstlnum + rex.lnum : 1;
+ long_u vcol;
+
+ if (REG_MULTI && (lnum <= 0
+ || lnum > wp->w_buffer->b_ml.ml_line_count))
+ lnum = 1;
+ vcol = (long_u)win_linetabsize(wp, lnum,
rex.line, col);
result = nfa_re_num_cmp(t->state->val, op, vcol + 1);
}
diff --git a/src/testdir/test_regexp_latin.vim b/src/testdir/test_regexp_latin.vim
index 6f3ffe23f..8df357fd4 100644
--- a/src/testdir/test_regexp_latin.vim
+++ b/src/testdir/test_regexp_latin.vim
@@ -1145,7 +1145,13 @@ def Test_compare_columns()
enddef
def Test_compare_column_matchstr()
+ # do some search in text to set the line number, it should be ignored in
+ # matchstr().
enew
+ setline(1, ['one', 'two', 'three'])
+ :3
+ :/ee
+ bwipe!
set re=1
call assert_equal('aaa', matchstr('aaaaaaaaaaaaaaaaaaaa', '.*\%<5v'))
set re=2
diff --git a/src/version.c b/src/version.c
index bff11c710..5fdf817a5 100644
--- a/src/version.c
+++ b/src/version.c
@@ -704,6 +704,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 414,
+/**/
413,
/**/
412,