diff options
| -rw-r--r-- | src/nvim/getchar.c | 7 | ||||
| -rw-r--r-- | src/nvim/testdir/test_mapping.vim | 11 | 
2 files changed, 17 insertions, 1 deletions
| diff --git a/src/nvim/getchar.c b/src/nvim/getchar.c index 555eadb5d4..1fb3f827c1 100644 --- a/src/nvim/getchar.c +++ b/src/nvim/getchar.c @@ -3248,6 +3248,9 @@ int buf_do_map(int maptype, MapArguments *args, int mode, bool is_abbrev, buf_T                    mpp = &(mp->m_next);                    continue;                  } +                if (did_simplify && keyround == 1 && !mp->m_simplified) { +                  break; +                }                  // We reset the indicated mode bits. If nothing                  // is left the entry is deleted below.                  mp->m_mode &= ~mode; @@ -3319,7 +3322,9 @@ int buf_do_map(int maptype, MapArguments *args, int mode, bool is_abbrev, buf_T      if (maptype == 1) {        // delete entry        if (!did_it) { -        retval = 2;  // no match +        if (!did_simplify || keyround == 2) { +          retval = 2;  // no match +        }        } else if (*lhs == Ctrl_C) {          // If CTRL-C has been unmapped, reuse it for Interrupting.          if (map_table == buf->b_maphash) { diff --git a/src/nvim/testdir/test_mapping.vim b/src/nvim/testdir/test_mapping.vim index 8c399ff3b1..88735a34b8 100644 --- a/src/nvim/testdir/test_mapping.vim +++ b/src/nvim/testdir/test_mapping.vim @@ -761,4 +761,15 @@ func Test_mouse_drag_insert_map()    set mouse&  endfunc +func Test_unmap_simplfied() +  map <C-I> foo +  map <Tab> bar +  call assert_equal('foo', maparg('<C-I>')) +  call assert_equal('bar', maparg('<Tab>')) +  unmap <C-I> +  call assert_equal('', maparg('<C-I>')) +  call assert_equal('bar', maparg('<Tab>')) +  unmap <Tab> +endfunc +  " vim: shiftwidth=2 sts=2 expandtab | 
