From 059db5c29ffef283a4b90bab9228708fa32e3dd2 Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Sun, 15 Oct 2017 22:42:23 +0200 Subject: patch 8.0.1202: :wall gives an errof for a terminal window Problem: :wall gives an errof for a terminal window. (Marius Gedminas) Solution: Don't try writing a buffer that can't be written. (Yasuhiro Matsumoto, closes #2190) --- src/ex_cmds.c | 2 +- src/testdir/test_terminal.vim | 9 +++++++++ src/version.c | 2 ++ 3 files changed, 12 insertions(+), 1 deletion(-) diff --git a/src/ex_cmds.c b/src/ex_cmds.c index b4351b23d..60f47bbd2 100644 --- a/src/ex_cmds.c +++ b/src/ex_cmds.c @@ -3400,7 +3400,7 @@ do_wqall(exarg_T *eap) FOR_ALL_BUFFERS(buf) { - if (bufIsChanged(buf)) + if (bufIsChanged(buf) && !bt_dontwrite(buf)) { /* * Check if there is a reason the buffer cannot be written: diff --git a/src/testdir/test_terminal.vim b/src/testdir/test_terminal.vim index cff85a459..92dcd1a57 100644 --- a/src/testdir/test_terminal.vim +++ b/src/testdir/test_terminal.vim @@ -676,3 +676,12 @@ func Test_terminal_tmap() call TerminalTmap(1) call TerminalTmap(0) endfunc + +func Test_terminal_wall() + let buf = Run_shell_in_terminal({}) + wall + call Stop_shell_in_terminal(buf) + call term_wait(buf) + exe buf . 'bwipe' + unlet g:job +endfunc diff --git a/src/version.c b/src/version.c index edc29cc4f..0f4d23ba9 100644 --- a/src/version.c +++ b/src/version.c @@ -761,6 +761,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 1202, /**/ 1201, /**/ -- cgit v1.2.1