]> granicus.if.org Git - vim/commitdiff
patch 8.0.0917: MS-Windows:CTRL-C handling in terminal window is wrong v8.0.0917
authorBram Moolenaar <Bram@vim.org>
Sat, 12 Aug 2017 14:39:05 +0000 (16:39 +0200)
committerBram Moolenaar <Bram@vim.org>
Sat, 12 Aug 2017 14:39:05 +0000 (16:39 +0200)
Problem:    MS-Windows:CTRL-C handling in terminal window is wrong
Solution:   Pass CTRL-C as a key. Turn CTRL-BREAK into a key stroke. (Yasuhiro
            Matsumoto, closes #1965)

src/os_win32.c
src/terminal.c
src/version.c

index 496f95f72018bed12f4866da5c526e25582e41ae..c6d9ad1671f991e109817efb5f23aa3d9b8f2ccd 100644 (file)
@@ -3741,6 +3741,9 @@ mch_free_acl(vim_acl_T acl)
 handler_routine(
     DWORD dwCtrlType)
 {
+    INPUT_RECORD ir;
+    DWORD out;
+
     switch (dwCtrlType)
     {
     case CTRL_C_EVENT:
@@ -3750,6 +3753,16 @@ handler_routine(
 
     case CTRL_BREAK_EVENT:
        g_fCBrkPressed  = TRUE;
+       ctrl_break_was_pressed = TRUE;
+       /* ReadConsoleInput is blocking, send a key event to continue. */
+       ir.EventType = KEY_EVENT;
+       ir.Event.KeyEvent.bKeyDown = TRUE;
+       ir.Event.KeyEvent.wRepeatCount = 1;
+       ir.Event.KeyEvent.wVirtualKeyCode = VK_CANCEL;
+       ir.Event.KeyEvent.wVirtualScanCode = 0;
+       ir.Event.KeyEvent.dwControlKeyState = 0;
+       ir.Event.KeyEvent.uChar.UnicodeChar = 0;
+       WriteConsoleInput(g_hConIn, &ir, 1, &out);
        return TRUE;
 
     /* fatal events: shut down gracefully */
index 0b4c2ef68ab98e99f7d840faba2842fe31a7855b..e8727ee6e5d7a189fc0848d837aa0490398279fb 100644 (file)
@@ -1207,12 +1207,8 @@ terminal_loop(void)
        may_send_sigint(c, curbuf->b_term->tl_job->jv_pid, 0);
 #endif
 #ifdef WIN3264
-       /* On Windows we do not know whether the job can handle CTRL-C itself
-        * or not.  Therefore CTRL-C only sends a CTRL_C_EVENT to avoid killing
-        * the shell instead of a command running in the shell.
+       /* On Windows winpty handles CTRL-C, don't send a CTRL_C_EVENT.
         * Use CTRL-BREAK to kill the job. */
-       if (c == Ctrl_C)
-           mch_signal_job(curbuf->b_term->tl_job, (char_u *)"int");
        if (ctrl_break_was_pressed)
            mch_signal_job(curbuf->b_term->tl_job, (char_u *)"kill");
 #endif
@@ -1544,7 +1540,8 @@ term_channel_closed(channel_T *ch)
                    ch_log(NULL, "terminal job finished, opening window");
                    vim_snprintf(buf, sizeof(buf),
                            term->tl_opencmd == NULL
-                               ? "botright sbuf %d" : term->tl_opencmd, fnum);
+                                   ? "botright sbuf %d"
+                                   : (char *)term->tl_opencmd, fnum);
                    do_cmdline_cmd((char_u *)buf);
                }
                else
index 8ca7d7022fb9c5d57bcaf6a8073de2d985417cf6..3bd461af07f9c56514cc9aa47911cef2be1eb18a 100644 (file)
@@ -769,6 +769,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    917,
 /**/
     916,
 /**/