summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMartin Tournoij <martin@arp242.net>2022-10-22 09:02:56 +0100
committerBram Moolenaar <Bram@vim.org>2022-10-22 09:02:56 +0100
commit9c50eeb40117413bf59a9da904c8d0921ed0a6e6 (patch)
treec7ffa39307f8984d9123ff831836f93cdd79aeac
parent436e5d395fd629c8d33b5cf7b373aad007f16851 (diff)
downloadvim-git-9c50eeb40117413bf59a9da904c8d0921ed0a6e6.tar.gz
patch 9.0.0815v9.0.0815
-rw-r--r--src/ex_cmds.c14
-rw-r--r--src/testdir/test_shell.vim4
-rw-r--r--src/version.c2
3 files changed, 10 insertions, 10 deletions
diff --git a/src/ex_cmds.c b/src/ex_cmds.c
index 93f9dd700..676ab704b 100644
--- a/src/ex_cmds.c
+++ b/src/ex_cmds.c
@@ -929,6 +929,8 @@ do_bang(
STRCAT(t, newcmd);
if (ins_prevcmd)
STRCAT(t, prevcmd);
+ else
+ vim_free(t);
p = t + STRLEN(t);
STRCAT(t, trailarg);
vim_free(newcmd);
@@ -957,17 +959,13 @@ do_bang(
}
} while (trailarg != NULL);
- // Don't do anything if there is no command as there isn't really anything
- // useful in running "sh -c ''". Avoids changing "prevcmd".
- if (STRLEN(newcmd) == 0)
+ // Don't clear "prevcmd" if there is no command to run.
+ if (STRLEN(newcmd) > 0)
{
- vim_free(newcmd);
- return;
+ vim_free(prevcmd);
+ prevcmd = newcmd;
}
- vim_free(prevcmd);
- prevcmd = newcmd;
-
if (bangredo) // put cmd in redo buffer for ! command
{
// If % or # appears in the command, it must have been escaped.
diff --git a/src/testdir/test_shell.vim b/src/testdir/test_shell.vim
index 1b4b1f980..3ac4681e3 100644
--- a/src/testdir/test_shell.vim
+++ b/src/testdir/test_shell.vim
@@ -268,8 +268,8 @@ func Test_shell_repeat()
call assert_equal(['Cmd: [-c echo coconut]'], readfile('Xlog'))
call writefile(['empty'], 'Xlog')
- call feedkeys(":!\<CR>", 'xt') " :! is a no-op
- call assert_equal(['empty'], readfile('Xlog'))
+ call feedkeys(":!\<CR>", 'xt') " :!
+ call assert_equal(['Cmd: [-c ]'], readfile('Xlog'))
call feedkeys(":!!\<CR>", 'xt') " :! doesn't clear previous command
call assert_equal(['Cmd: [-c echo coconut]'], readfile('Xlog'))
diff --git a/src/version.c b/src/version.c
index 690a1973a..237cd7c40 100644
--- a/src/version.c
+++ b/src/version.c
@@ -696,6 +696,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 815,
+/**/
814,
/**/
813,