diff options
author | James McCoy <jamessan@jamessan.com> | 2020-10-05 22:07:52 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-10-05 22:07:52 -0400 |
commit | 27b811dc1f69a31924ddcd3c0a3cbbe138923c96 (patch) | |
tree | d0df14412fe12859ae57ed3dde2846c7d80c0b40 /src | |
parent | f8a5b4bdce489f4df7df15d0b363b608853b92d6 (diff) | |
parent | 2f06413dfb3624381f112b7d8661fde659c279e7 (diff) | |
download | rneovim-27b811dc1f69a31924ddcd3c0a3cbbe138923c96.tar.gz rneovim-27b811dc1f69a31924ddcd3c0a3cbbe138923c96.tar.bz2 rneovim-27b811dc1f69a31924ddcd3c0a3cbbe138923c96.zip |
Merge pull request #13042 from godlygeek/unmapped_meta_is_esc
Treat unmapped ALT/META as ESC+c in all modes
Closes #7972
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/edit.c | 8 | ||||
-rw-r--r-- | src/nvim/getchar.c | 11 |
2 files changed, 11 insertions, 8 deletions
diff --git a/src/nvim/edit.c b/src/nvim/edit.c index 1e149da1dc..de2346a9d8 100644 --- a/src/nvim/edit.c +++ b/src/nvim/edit.c @@ -1254,14 +1254,6 @@ check_pum: normalchar: // Insert a normal character. - if (mod_mask == MOD_MASK_ALT || mod_mask == MOD_MASK_META) { - // Unmapped ALT/META chord behaves like ESC+c. #8213 - stuffcharReadbuff(ESC); - stuffcharReadbuff(s->c); - u_sync(false); - break; - } - if (!p_paste) { // Trigger InsertCharPre. char_u *str = do_insert_char_pre(s->c); diff --git a/src/nvim/getchar.c b/src/nvim/getchar.c index ecb3931b82..cbd9582f8b 100644 --- a/src/nvim/getchar.c +++ b/src/nvim/getchar.c @@ -1528,6 +1528,17 @@ int vgetc(void) c = utf_ptr2char(buf); } + // If mappings are enabled (i.e., not Ctrl-v) and the user directly typed + // something with a meta- or alt- modifier that was not mapped, interpret + // <M-x> as <Esc>x rather than as an unbound meta keypress. #8213 + if (!no_mapping && KeyTyped + && (mod_mask == MOD_MASK_ALT || mod_mask == MOD_MASK_META)) { + mod_mask = 0; + stuffcharReadbuff(c); + u_sync(false); + c = ESC; + } + break; } } |