aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGhjuvan Lacambre <code@lacamb.re>2020-06-22 23:22:58 +0200
committerGitHub <noreply@github.com>2020-06-22 23:22:58 +0200
commit721f69c4af8bc81ba04088e7b56f8cdba653b418 (patch)
treef132ef87672b996d4e81b51d25b241b30f41f037
parent1619410a059fd008b3f248ea81aca30036a0fb90 (diff)
downloadrneovim-721f69c4af8bc81ba04088e7b56f8cdba653b418.tar.gz
rneovim-721f69c4af8bc81ba04088e7b56f8cdba653b418.tar.bz2
rneovim-721f69c4af8bc81ba04088e7b56f8cdba653b418.zip
terminal: preserve mode when using <Cmd>wincmd in terminal mode (#12254)
-rw-r--r--src/nvim/terminal.c12
-rw-r--r--test/functional/terminal/window_split_tab_spec.lua10
2 files changed, 21 insertions, 1 deletions
diff --git a/src/nvim/terminal.c b/src/nvim/terminal.c
index a096b77ac6..6a13341a89 100644
--- a/src/nvim/terminal.c
+++ b/src/nvim/terminal.c
@@ -489,7 +489,17 @@ static int terminal_execute(VimState *state, int key)
terminal_send_key(s->term, key);
}
- return curbuf->handle == s->term->buf_handle;
+ if (curbuf->terminal == NULL) {
+ return 0;
+ }
+ if (s->term != curbuf->terminal) {
+ invalidate_terminal(s->term, s->term->cursor.row, s->term->cursor.row + 1);
+ invalidate_terminal(curbuf->terminal,
+ curbuf->terminal->cursor.row,
+ curbuf->terminal->cursor.row + 1);
+ s->term = curbuf->terminal;
+ }
+ return 1;
}
void terminal_destroy(Terminal *term)
diff --git a/test/functional/terminal/window_split_tab_spec.lua b/test/functional/terminal/window_split_tab_spec.lua
index 7b49a38e77..03bd336aec 100644
--- a/test/functional/terminal/window_split_tab_spec.lua
+++ b/test/functional/terminal/window_split_tab_spec.lua
@@ -103,4 +103,14 @@ describe(':terminal', function()
|
]])
end)
+
+ it('stays in terminal mode with <Cmd>wincmd', function()
+ command('terminal')
+ command('split')
+ command('terminal')
+ feed('a<Cmd>wincmd j<CR>')
+ eq(2, eval("winnr()"))
+ eq('t', eval('mode()'))
+ end)
+
end)