aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornotomo <notomo.motono@gmail.com>2022-07-25 10:43:39 +0900
committerGitHub <noreply@github.com>2022-07-25 09:43:39 +0800
commit46e3e1c7280a409462cceb520fe12259b5ba9937 (patch)
treea0fabe872ed7b4194ee6ed9551cc95d6e022cc07
parentd529523027c3d3c80c469fa689b0f65ec6f8298e (diff)
downloadrneovim-46e3e1c7280a409462cceb520fe12259b5ba9937.tar.gz
rneovim-46e3e1c7280a409462cceb520fe12259b5ba9937.tar.bz2
rneovim-46e3e1c7280a409462cceb520fe12259b5ba9937.zip
fix(api): make nvim_cmd mods.silent work correctly (#19489)
-rw-r--r--src/nvim/api/command.c2
-rw-r--r--test/functional/api/vim_spec.lua6
2 files changed, 7 insertions, 1 deletions
diff --git a/src/nvim/api/command.c b/src/nvim/api/command.c
index 4c2404a0d8..56ca624232 100644
--- a/src/nvim/api/command.c
+++ b/src/nvim/api/command.c
@@ -600,7 +600,7 @@ String nvim_cmd(uint64_t channel_id, Dict(cmd) *cmd, Dict(cmd_opts) *opts, Error
OBJ_TO_CMOD_FLAG(CMOD_SILENT, mods.silent, false, "'mods.silent'");
OBJ_TO_CMOD_FLAG(CMOD_ERRSILENT, mods.emsg_silent, false, "'mods.emsg_silent'");
- OBJ_TO_CMOD_FLAG(CMOD_UNSILENT, mods.silent, false, "'mods.unsilent'");
+ OBJ_TO_CMOD_FLAG(CMOD_UNSILENT, mods.unsilent, false, "'mods.unsilent'");
OBJ_TO_CMOD_FLAG(CMOD_SANDBOX, mods.sandbox, false, "'mods.sandbox'");
OBJ_TO_CMOD_FLAG(CMOD_NOAUTOCMD, mods.noautocmd, false, "'mods.noautocmd'");
OBJ_TO_CMOD_FLAG(CMOD_BROWSE, mods.browse, false, "'mods.browse'");
diff --git a/test/functional/api/vim_spec.lua b/test/functional/api/vim_spec.lua
index 3724dbf820..17de6730fb 100644
--- a/test/functional/api/vim_spec.lua
+++ b/test/functional/api/vim_spec.lua
@@ -3733,6 +3733,12 @@ describe('API', function()
eq("", meths.cmd({ cmd = "Foo", bang = false }, { output = true }))
end)
it('works with modifiers', function()
+ -- with :silent output is still captured
+ eq('1',
+ meths.cmd({ cmd = 'echomsg', args = { '1' }, mods = { silent = true } },
+ { output = true }))
+ -- with :silent message isn't added to message history
+ eq('', meths.cmd({ cmd = 'messages' }, { output = true }))
meths.create_user_command("Foo", 'set verbose', {})
eq(" verbose=1", meths.cmd({ cmd = "Foo", mods = { verbose = 1 } }, { output = true }))
eq(0, meths.get_option_value("verbose", {}))