aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2019-04-11 13:31:05 +0200
committerGitHub <noreply@github.com>2019-04-11 13:31:05 +0200
commitb358054694765b595ff3ef64a5b0bba98628c218 (patch)
tree9fa3588c03a633a70820f6dc025858946f877484
parent21b108fe445452e6e35621184fc77623dc64f9a3 (diff)
parent5cf96fc14108812433b5abcab31568168bc50d57 (diff)
downloadrneovim-b358054694765b595ff3ef64a5b0bba98628c218.tar.gz
rneovim-b358054694765b595ff3ef64a5b0bba98628c218.tar.bz2
rneovim-b358054694765b595ff3ef64a5b0bba98628c218.zip
Merge pull request #9880 from janlazo/vim-8.0.0725
closes #9879
-rw-r--r--src/nvim/normal.c10
-rw-r--r--src/nvim/ops.c4
-rw-r--r--src/nvim/testdir/test_window_cmd.vim5
3 files changed, 17 insertions, 2 deletions
diff --git a/src/nvim/normal.c b/src/nvim/normal.c
index abee28e37e..5217db5b42 100644
--- a/src/nvim/normal.c
+++ b/src/nvim/normal.c
@@ -6526,8 +6526,14 @@ static void n_start_visual_mode(int c)
*/
static void nv_window(cmdarg_T *cap)
{
- if (!checkclearop(cap->oap))
- do_window(cap->nchar, cap->count0, NUL); /* everything is in window.c */
+ if (cap->nchar == ':') {
+ // "CTRL-W :" is the same as typing ":"; useful in a terminal window
+ cap->cmdchar = ':';
+ cap->nchar = NUL;
+ nv_colon(cap);
+ } else if (!checkclearop(cap->oap)) {
+ do_window(cap->nchar, cap->count0, NUL); // everything is in window.c
+ }
}
/*
diff --git a/src/nvim/ops.c b/src/nvim/ops.c
index 0ed96f0e57..79a7271819 100644
--- a/src/nvim/ops.c
+++ b/src/nvim/ops.c
@@ -153,6 +153,10 @@ int get_op_type(int char1, int char2)
if (opchars[i][0] == char1 && opchars[i][1] == char2) {
break;
}
+ if (i == (int)(ARRAY_SIZE(opchars) - 1)) {
+ internal_error("get_op_type()");
+ break;
+ }
}
return i;
}
diff --git a/src/nvim/testdir/test_window_cmd.vim b/src/nvim/testdir/test_window_cmd.vim
index d3b496635d..003a23ea7b 100644
--- a/src/nvim/testdir/test_window_cmd.vim
+++ b/src/nvim/testdir/test_window_cmd.vim
@@ -691,4 +691,9 @@ func Test_winnr()
only | tabonly
endfunc
+func Test_window_colon_command()
+ " This was reading invalid memory.
+ exe "norm! v\<C-W>:\<C-U>echo v:version"
+endfunc
+
" vim: shiftwidth=2 sts=2 expandtab