summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2019-08-15 20:58:54 +0200
committerBram Moolenaar <Bram@vim.org>2019-08-15 20:58:54 +0200
commita4b2699e28a30dcc4d1696b317f24a8904ec2a06 (patch)
tree1fdfacb6d7b165248e0fefdc73304b4be43eb833
parent185d68a9d08f18440af93dd0f232e38f1819ddb2 (diff)
patch 8.1.1848: 'langmap' is not used for CTRL-W command in terminalv8.1.1848
Problem: 'langmap' is not used for CTRL-W command in terminal. Solution: Push the command in the typeahead buffer instead of the stuff buffer. (closes #4814)
-rw-r--r--src/terminal.c9
-rw-r--r--src/testdir/test_terminal.vim7
-rw-r--r--src/version.c2
3 files changed, 16 insertions, 2 deletions
diff --git a/src/terminal.c b/src/terminal.c
index 51e242f196..95347a16ca 100644
--- a/src/terminal.c
+++ b/src/terminal.c
@@ -2372,8 +2372,13 @@ terminal_loop(int blocking)
}
else if (termwinkey == 0 || c != termwinkey)
{
- stuffcharReadbuff(Ctrl_W);
- stuffcharReadbuff(c);
+ char_u buf[MB_MAXBYTES + 2];
+
+ // Put the command into the typeahead buffer, when using the
+ // stuff buffer KeyStuffed is set and 'langmap' won't be used.
+ buf[0] = Ctrl_W;
+ buf[(*mb_char2bytes)(c, buf + 1) + 1] = NUL;
+ ins_typebuf(buf, REMAP_NONE, 0, TRUE, FALSE);
ret = OK;
goto theend;
}
diff --git a/src/testdir/test_terminal.vim b/src/testdir/test_terminal.vim
index 5496b6325e..e173b42b83 100644
--- a/src/testdir/test_terminal.vim
+++ b/src/testdir/test_terminal.vim
@@ -1686,6 +1686,13 @@ func Test_terminal_termwinkey()
call feedkeys("\<C-W>w", 'tx')
call assert_equal(termwin, win_getid())
+ set langmap=xjyk
+ call feedkeys("\<C-L>x", 'tx')
+ call assert_equal(thiswin, win_getid())
+ call feedkeys("\<C-W>y", 'tx')
+ call assert_equal(termwin, win_getid())
+ set langmap=
+
call feedkeys("\<C-L>gt", "xt")
call assert_equal(3, tabpagenr())
tabprev
diff --git a/src/version.c b/src/version.c
index b8a84ac9d8..3ec385cfbc 100644
--- a/src/version.c
+++ b/src/version.c
@@ -770,6 +770,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1848,
+/**/
1847,
/**/
1846,