summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-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 51e242f19..95347a16c 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 5496b6325..e173b42b8 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 b8a84ac9d..3ec385cfb 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,