]> granicus.if.org Git - vim/commitdiff
patch 8.1.0042: if omni completion opens a window Insert mode is stopped v8.1.0042
authorBram Moolenaar <Bram@vim.org>
Sun, 10 Jun 2018 12:39:52 +0000 (14:39 +0200)
committerBram Moolenaar <Bram@vim.org>
Sun, 10 Jun 2018 12:39:52 +0000 (14:39 +0200)
Problem:    If omni completion opens a window Insert mode is stopped.
            (Hirohito Higashi)
Solution:   Only set stop_insert_mode in a prompt buffer window.

src/version.c
src/window.c

index 71283ed0db20feea5153303295fa01229bf7b3ed..4ab241eb90780ebce1105b81d0fb3ec80f8ad8db 100644 (file)
@@ -761,6 +761,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    42,
 /**/
     41,
 /**/
index 27ef9d5cc27381e3a73a9a34f0a2356c6e6b5426..74e3c046985b62b2c245ff66fe86a3f03152100e 100644 (file)
@@ -2107,17 +2107,22 @@ win_equal_rec(
     static void
 leaving_window(win_T *win)
 {
+    // Only matters for a prompt window.
+    if (!bt_prompt(win->w_buffer))
+       return;
+
     // When leaving a prompt window stop Insert mode and perhaps restart
     // it when entering that window again.
     win->w_buffer->b_prompt_insert = restart_edit;
     restart_edit = NUL;
 
     // When leaving the window (or closing the window) was done from a
-    // callback we need to break out of the Insert mode loop.
+    // callback we need to break out of the Insert mode loop and restart Insert
+    // mode when entering the window again.
     if (State & INSERT)
     {
        stop_insert_mode = TRUE;
-       if (bt_prompt(win->w_buffer) && win->w_buffer->b_prompt_insert == NUL)
+       if (win->w_buffer->b_prompt_insert == NUL)
            win->w_buffer->b_prompt_insert = 'A';
     }
 }
@@ -2125,12 +2130,17 @@ leaving_window(win_T *win)
     static void
 entering_window(win_T *win)
 {
+    // Only matters for a prompt window.
+    if (!bt_prompt(win->w_buffer))
+       return;
+
     // When switching to a prompt buffer that was in Insert mode, don't stop
     // Insert mode, it may have been set in leaving_window().
-    if (bt_prompt(win->w_buffer) && win->w_buffer->b_prompt_insert != NUL)
+    if (win->w_buffer->b_prompt_insert != NUL)
        stop_insert_mode = FALSE;
 
-    // When entering the prompt window may restart Insert mode.
+    // When entering the prompt window restart Insert mode if we were in Insert
+    // mode when we left it.
     restart_edit = win->w_buffer->b_prompt_insert;
 }
 #endif