Mercurial > vim
diff src/edit.c @ 14985:4ebda55537a5 v8.1.0504
patch 8.1.0504: when CTRL-C is mapped it triggers InsertLeave
commit https://github.com/vim/vim/commit/4dbc2627641a6b950c30c31cbf7b7e6c36da1927
Author: Bram Moolenaar <Bram@vim.org>
Date: Fri Nov 2 11:59:15 2018 +0100
patch 8.1.0504: when CTRL-C is mapped it triggers InsertLeave
Problem: When CTRL-C is mapped it triggers InsertLeave.
Solution: Make CTRL-C behave the same way when typed or used in a mapping.
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Fri, 02 Nov 2018 12:00:07 +0100 |
parents | 27b9a84395b5 |
children | 3a94f7918980 |
line wrap: on
line diff
--- a/src/edit.c +++ b/src/edit.c @@ -1048,7 +1048,10 @@ doESCkey: if (ins_esc(&count, cmdchar, nomove)) { - if (cmdchar != 'r' && cmdchar != 'v') + // When CTRL-C was typed got_int will be set, with the result + // that the autocommands won't be executed. When mapped got_int + // is not set, but let's keep the behavior the same. + if (cmdchar != 'r' && cmdchar != 'v' && c != Ctrl_C) ins_apply_autocmds(EVENT_INSERTLEAVE); did_cursorhold = FALSE; return (c == Ctrl_O); @@ -2408,7 +2411,7 @@ has_compl_option(int dict_opt) int vim_is_ctrl_x_key(int c) { - /* Always allow ^R - let it's results then be checked */ + // Always allow ^R - let its results then be checked if (c == Ctrl_R) return TRUE;