aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2024-03-21 07:34:43 +0800
committerzeertzjq <zeertzjq@outlook.com>2024-03-22 06:04:37 +0800
commit271879dd490b8f9c20c5541e60ca2a2924b631d9 (patch)
treeccf00747b396ebba3f8424e6c7b92298c03ab664
parent774455dc371736e83afc62eca67ceec3e2dedb5d (diff)
downloadrneovim-271879dd490b8f9c20c5541e60ca2a2924b631d9.tar.gz
rneovim-271879dd490b8f9c20c5541e60ca2a2924b631d9.tar.bz2
rneovim-271879dd490b8f9c20c5541e60ca2a2924b631d9.zip
vim-patch:9.1.0192: drop: don't rewind when editing the same file
Problem: :drop tries to :rewind the argumentlist, which results in E37 (after v9.1.0046) Solution: instead of calling ex_rewind(), call open_buffer() only when re-using the initial empty buffer fixes: vim/vim#14219 closes: vim/vim#14220 https://github.com/vim/vim/commit/978178823b7c62a0249411f3d1f584f8a3144c5d Co-authored-by: Christian Brabandt <cb@256bit.org>
-rw-r--r--src/nvim/ex_cmds2.c4
-rw-r--r--test/functional/ex_cmds/drop_spec.lua20
-rw-r--r--test/old/testdir/test_excmd.vim16
3 files changed, 37 insertions, 3 deletions
diff --git a/src/nvim/ex_cmds2.c b/src/nvim/ex_cmds2.c
index a34eb0232b..fc50664ce0 100644
--- a/src/nvim/ex_cmds2.c
+++ b/src/nvim/ex_cmds2.c
@@ -870,7 +870,9 @@ void ex_drop(exarg_T *eap)
buf_check_timestamp(curbuf);
curbuf->b_p_ar = save_ar;
}
- ex_rewind(eap);
+ if (buf->b_ml.ml_flags & ML_EMPTY) {
+ open_buffer(false, eap, 0);
+ }
return;
}
}
diff --git a/test/functional/ex_cmds/drop_spec.lua b/test/functional/ex_cmds/drop_spec.lua
index cbda5aac98..f6e84e34a5 100644
--- a/test/functional/ex_cmds/drop_spec.lua
+++ b/test/functional/ex_cmds/drop_spec.lua
@@ -2,6 +2,7 @@ local helpers = require('test.functional.helpers')(after_each)
local command = helpers.command
local Screen = require('test.functional.ui.screen')
local clear, feed, feed_command = helpers.clear, helpers.feed, helpers.feed_command
+local exec = helpers.exec
describe(':drop', function()
local screen
@@ -16,7 +17,7 @@ describe(':drop', function()
[2] = { reverse = true },
[3] = { bold = true },
})
- command('set laststatus=2 shortmess-=F')
+ command('set nohidden laststatus=2 shortmess-=F')
end)
it('works like :e when called with only one window open', function()
@@ -43,7 +44,6 @@ describe(':drop', function()
end)
it("splits off a new window when a buffer can't be abandoned", function()
- command('set nohidden')
feed_command('edit tmp1')
feed_command('vsplit')
feed_command('edit tmp2')
@@ -59,4 +59,20 @@ describe(':drop', function()
"tmp3" [New] |
]])
end)
+
+ -- oldtest: Test_drop_modified_file()
+ it('does not cause E37 with modified same file', function()
+ exec([[
+ edit Xdrop_modified.txt
+ call setline(1, 'The quick brown fox jumped over the lazy dogs')
+ ]])
+ feed_command('drop Xdrop_modified.txt')
+ screen:expect([[
+ ^The quick brown fox jumped over the|
+ lazy dogs |
+ {0:~ }|*6
+ {1:Xdrop_modified.txt [+] }|
+ "Xdrop_modified.txt" [New] |
+ ]])
+ end)
end)
diff --git a/test/old/testdir/test_excmd.vim b/test/old/testdir/test_excmd.vim
index b7356c22fa..4a780078fd 100644
--- a/test/old/testdir/test_excmd.vim
+++ b/test/old/testdir/test_excmd.vim
@@ -3,6 +3,7 @@
source check.vim
source shared.vim
source term_util.vim
+source screendump.vim
func Test_ex_delete()
new
@@ -758,4 +759,19 @@ func Test_ex_address_range_overflow()
call assert_fails(':--+foobar', 'E492:')
endfunc
+func Test_drop_modified_file()
+ CheckScreendump
+ let lines =<< trim END
+ call setline(1, 'The quick brown fox jumped over the lazy dogs')
+ END
+ call writefile([''], 'Xdrop_modified.txt', 'D')
+ call writefile(lines, 'Xtest_drop_modified', 'D')
+ let buf = RunVimInTerminal('-S Xtest_drop_modified Xdrop_modified.txt', {'rows': 10,'columns': 40})
+ call term_sendkeys(buf, ":drop Xdrop_modified.txt\<CR>")
+ call VerifyScreenDump(buf, 'Test_drop_modified_1', {})
+
+ " clean up
+ call StopVimInTerminal(buf)
+endfunc
+
" vim: shiftwidth=2 sts=2 expandtab