diff options
author | zeertzjq <zeertzjq@outlook.com> | 2023-04-16 17:44:14 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-04-16 17:44:14 +0800 |
commit | b28683d25281847716ca0003cecedb3f3a34d089 (patch) | |
tree | ab5e93ad8c642af51d209bafb372e48134d7a210 | |
parent | c54592bfdacf08823a03d5aa251f49b906f3157d (diff) | |
download | rneovim-b28683d25281847716ca0003cecedb3f3a34d089.tar.gz rneovim-b28683d25281847716ca0003cecedb3f3a34d089.tar.bz2 rneovim-b28683d25281847716ca0003cecedb3f3a34d089.zip |
vim-patch:9.0.0947: invalid memory access in substitute with function (#23126)
Problem: Invalid memory access in substitute with function that goes to
another file.
Solution: Check for text locked in CTRL-W gf.
https://github.com/vim/vim/commit/cc762a48d42b579fb7bdec2c614636b830342dd5
Co-authored-by: Bram Moolenaar <Bram@vim.org>
-rw-r--r-- | src/nvim/normal.c | 2 | ||||
-rw-r--r-- | src/nvim/window.c | 11 | ||||
-rw-r--r-- | test/old/testdir/test_substitute.vim | 19 |
3 files changed, 27 insertions, 5 deletions
diff --git a/src/nvim/normal.c b/src/nvim/normal.c index 718c51deb0..5fcdf5d4c1 100644 --- a/src/nvim/normal.c +++ b/src/nvim/normal.c @@ -462,7 +462,7 @@ static bool check_text_locked(oparg_T *oap) /// If text is locked, "curbuf->b_ro_locked" or "allbuf_lock" is set: /// Give an error message, possibly beep and return true. /// "oap" may be NULL. -static bool check_text_or_curbuf_locked(oparg_T *oap) +bool check_text_or_curbuf_locked(oparg_T *oap) { if (check_text_locked(oap)) { return true; diff --git a/src/nvim/window.c b/src/nvim/window.c index 75fa61fb1e..a2e1d1ab04 100644 --- a/src/nvim/window.c +++ b/src/nvim/window.c @@ -504,6 +504,9 @@ newwindow: case Ctrl_F: { wingotofile: CHECK_CMDWIN; + if (check_text_or_curbuf_locked(NULL)) { + break; + } linenr_T lnum = -1; char *ptr = grab_file_name(Prenum1, &lnum); @@ -1068,10 +1071,10 @@ int win_split(int size, int flags) return win_split_ins(size, flags, NULL, 0); } -// When "new_wp" is NULL: split the current window in two. -// When "new_wp" is not NULL: insert this window at the far -// top/left/right/bottom. -// return FAIL for failure, OK otherwise +/// When "new_wp" is NULL: split the current window in two. +/// When "new_wp" is not NULL: insert this window at the far +/// top/left/right/bottom. +/// @return FAIL for failure, OK otherwise int win_split_ins(int size, int flags, win_T *new_wp, int dir) { win_T *wp = new_wp; diff --git a/test/old/testdir/test_substitute.vim b/test/old/testdir/test_substitute.vim index b2abbae168..f15ef122ec 100644 --- a/test/old/testdir/test_substitute.vim +++ b/test/old/testdir/test_substitute.vim @@ -1090,6 +1090,25 @@ func Test_sub_edit_scriptfile() bwipe! endfunc +" This was editing another file from the expression. +func Test_sub_expr_goto_other_file() + call writefile([''], 'Xfileone', 'D') + enew! + call setline(1, ['a', 'b', 'c', 'd', + \ 'Xfileone zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz']) + + func g:SplitGotoFile() + exe "sil! norm 0\<C-W>gf" + return '' + endfunc + + $ + s/\%')/\=g:SplitGotoFile() + + delfunc g:SplitGotoFile + bwipe! +endfunc + " Test for the 2-letter and 3-letter :substitute commands func Test_substitute_short_cmd() new |