mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 8.0.0917: MS-Windows:CTRL-C handling in terminal window is wrong
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)
This commit is contained in:
parent
37c4583594
commit
589b1109c5
@ -3741,6 +3741,9 @@ mch_free_acl(vim_acl_T acl)
|
|||||||
handler_routine(
|
handler_routine(
|
||||||
DWORD dwCtrlType)
|
DWORD dwCtrlType)
|
||||||
{
|
{
|
||||||
|
INPUT_RECORD ir;
|
||||||
|
DWORD out;
|
||||||
|
|
||||||
switch (dwCtrlType)
|
switch (dwCtrlType)
|
||||||
{
|
{
|
||||||
case CTRL_C_EVENT:
|
case CTRL_C_EVENT:
|
||||||
@ -3750,6 +3753,16 @@ handler_routine(
|
|||||||
|
|
||||||
case CTRL_BREAK_EVENT:
|
case CTRL_BREAK_EVENT:
|
||||||
g_fCBrkPressed = TRUE;
|
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;
|
return TRUE;
|
||||||
|
|
||||||
/* fatal events: shut down gracefully */
|
/* fatal events: shut down gracefully */
|
||||||
|
@ -1207,12 +1207,8 @@ terminal_loop(void)
|
|||||||
may_send_sigint(c, curbuf->b_term->tl_job->jv_pid, 0);
|
may_send_sigint(c, curbuf->b_term->tl_job->jv_pid, 0);
|
||||||
#endif
|
#endif
|
||||||
#ifdef WIN3264
|
#ifdef WIN3264
|
||||||
/* On Windows we do not know whether the job can handle CTRL-C itself
|
/* On Windows winpty handles CTRL-C, don't send a CTRL_C_EVENT.
|
||||||
* or not. Therefore CTRL-C only sends a CTRL_C_EVENT to avoid killing
|
|
||||||
* the shell instead of a command running in the shell.
|
|
||||||
* Use CTRL-BREAK to kill the job. */
|
* 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)
|
if (ctrl_break_was_pressed)
|
||||||
mch_signal_job(curbuf->b_term->tl_job, (char_u *)"kill");
|
mch_signal_job(curbuf->b_term->tl_job, (char_u *)"kill");
|
||||||
#endif
|
#endif
|
||||||
@ -1544,7 +1540,8 @@ term_channel_closed(channel_T *ch)
|
|||||||
ch_log(NULL, "terminal job finished, opening window");
|
ch_log(NULL, "terminal job finished, opening window");
|
||||||
vim_snprintf(buf, sizeof(buf),
|
vim_snprintf(buf, sizeof(buf),
|
||||||
term->tl_opencmd == NULL
|
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);
|
do_cmdline_cmd((char_u *)buf);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -769,6 +769,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
917,
|
||||||
/**/
|
/**/
|
||||||
916,
|
916,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user