summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorChristian Brabandt <cb@256bit.org>2024-01-22 20:12:34 +0100
committerChristian Brabandt <cb@256bit.org>2024-01-22 20:12:34 +0100
commit7c71db3a58f658b4329b82ab603efa928d17bdbc (patch)
treeb78ab8ca9bc57c2c4ee758efc2d8e029bf736c18 /src
parent3b2c27415d7d6e97be9580b66528e8c19d19aade (diff)
patch 9.1.0043: ml_get: invalid lnum when :s replaces visual selectionv9.1.0043
Problem: ml_get: invalid lnum when :s replaces visual selection (@ropery) Solution: substitute may decrement the number of lines in a buffer, so validate, that the bottom lines of the visual selection stays within the max buffer line fixes: #13890 closes: #13892 Signed-off-by: Christian Brabandt <cb@256bit.org>
Diffstat (limited to 'src')
-rw-r--r--src/regexp.c4
-rw-r--r--src/testdir/test_visual.vim8
-rw-r--r--src/version.c2
3 files changed, 14 insertions, 0 deletions
diff --git a/src/regexp.c b/src/regexp.c
index c3bc4966c7..73552015e9 100644
--- a/src/regexp.c
+++ b/src/regexp.c
@@ -1318,6 +1318,10 @@ reg_match_visual(void)
top = curbuf->b_visual.vi_end;
bot = curbuf->b_visual.vi_start;
}
+ // a substitue command may have
+ // removed some lines
+ if (bot.lnum > curbuf->b_ml.ml_line_count)
+ bot.lnum = curbuf->b_ml.ml_line_count;
mode = curbuf->b_visual.vi_mode;
curswant = curbuf->b_visual.vi_curswant;
}
diff --git a/src/testdir/test_visual.vim b/src/testdir/test_visual.vim
index 401a3504ae..f0d8edcf84 100644
--- a/src/testdir/test_visual.vim
+++ b/src/testdir/test_visual.vim
@@ -1622,4 +1622,12 @@ func Test_visual_drag_out_of_window()
bwipe!
endfunc
+func Test_visual_substitute_visual()
+ new
+ call setline(1, ['one', 'two', 'three'])
+ call feedkeys("Gk\<C-V>j$:s/\\%V\\_.*\\%V/foobar\<CR>", 'tx')
+ call assert_equal(['one', 'foobar'], getline(1, '$'))
+ bwipe!
+endfunc
+
" vim: shiftwidth=2 sts=2 expandtab
diff --git a/src/version.c b/src/version.c
index 094658c3a4..783e2ba1b5 100644
--- a/src/version.c
+++ b/src/version.c
@@ -705,6 +705,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 43,
+/**/
42,
/**/
41,