diff options
author | zeertzjq <zeertzjq@outlook.com> | 2025-03-28 08:08:36 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-03-28 08:08:36 +0800 |
commit | ae98d0a560b08d901ee9aae85df634de0ae3fe0a (patch) | |
tree | 49849e2df8448d25d39cd4a2d41b578a0cffc917 /runtime/lua/vim/provider/python.lua | |
parent | 59e02ee93b6cfc64f961dbb4c489391eaa094ca2 (diff) | |
download | rneovim-ae98d0a560b08d901ee9aae85df634de0ae3fe0a.tar.gz rneovim-ae98d0a560b08d901ee9aae85df634de0ae3fe0a.tar.bz2 rneovim-ae98d0a560b08d901ee9aae85df634de0ae3fe0a.zip |
vim-patch:9.1.1247: fragile setup to get (preferred) keys from key_name_entry (#33102)
Problem: fragile setup to get (preferred) keys from key_name_entry
(after v9.1.1179)
Solution: refactor the code further, fix a bug with "pref_name" key
entry introduced in v9.1.1180 (Yee Cheng Chin)
The optimization introduced for using bsearch() with key_name_entry
in vim/vim#16788 was fragile as it required synchronizing a non-obvious index
(e.g. IDX_KEYNAME_SWU) with the array that could be accidentally changed
by any one adding a key to it. Furthermore, the "pref_name" that was
introduced in that change was unnecessary, and in fact introduced a bug,
as we don't always want to use the canonical name.
The bug is triggered when the user triggers auto-complete using a
keycode, such as `:set <Scroll<Tab>`. The bug would end up showing two
copies of `<ScrollWheelUp>` because both entries end up using the
canonical name.
In this change, remove `pref_name`, and simply use a boolean to track
whether an entry is an alt name or not and modify logic to respect that.
Add test to make sure auto-complete works with alt names
closes: vim/vim#16987
https://github.com/vim/vim/commit/7d8e7df55190e8e4e5a66f443e4440b52edf2fdb
In Nvim there is no `enabled` field, so put `is_alt` before `name` to
reduce the size of the struct.
Co-authored-by: Yee Cheng Chin <ychin.git@gmail.com>
Diffstat (limited to 'runtime/lua/vim/provider/python.lua')
0 files changed, 0 insertions, 0 deletions