diff options
author | Ghjuvan Lacambre <code@lacamb.re> | 2020-06-22 23:22:58 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-06-22 23:22:58 +0200 |
commit | 721f69c4af8bc81ba04088e7b56f8cdba653b418 (patch) | |
tree | f132ef87672b996d4e81b51d25b241b30f41f037 | |
parent | 1619410a059fd008b3f248ea81aca30036a0fb90 (diff) | |
download | rneovim-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.c | 12 | ||||
-rw-r--r-- | test/functional/terminal/window_split_tab_spec.lua | 10 |
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) |