commit 5fd386a893da0ba61d9890356005fd2b7f12dc79
parent c3c8d25293fd4da8fa867d18a7d54b2dc8c3d010
Author: zeertzjq <zeertzjq@outlook.com>
Date: Tue, 8 Jul 2025 07:22:02 +0800
Merge pull request #34828 from ncrpy/fix-get_keymap-lhsrawalt
fix(api): populate `lhsrawalt` in `nvim_get_keymap` response
Diffstat:
2 files changed, 12 insertions(+), 15 deletions(-)
diff --git a/src/nvim/mapping.c b/src/nvim/mapping.c
@@ -2894,7 +2894,10 @@ ArrayOf(Dict) keymap_array(String mode, buf_T *buf, Arena *arena)
}
// Check for correct mode
if (int_mode & current_maphash->m_mode) {
- kvi_push(mappings, DICT_OBJ(mapblock_fill_dict(current_maphash, NULL, buffer_value,
+ kvi_push(mappings, DICT_OBJ(mapblock_fill_dict(current_maphash,
+ current_maphash->m_alt
+ ? current_maphash->m_alt->m_keys : NULL,
+ buffer_value,
is_abbrev, false, arena)));
}
}
diff --git a/test/functional/api/keymap_spec.lua b/test/functional/api/keymap_spec.lua
@@ -316,7 +316,11 @@ describe('nvim_get_keymap', function()
}
local function cpomap(lhs, rhs, mode)
local ret = shallowcopy(cpo_table)
+ local lhsraw = api.nvim_eval(('"%s"'):format(lhs:gsub('\\', '\\\\'):gsub('<', '\\<*')))
+ local lhsrawalt = api.nvim_eval(('"%s"'):format(lhs:gsub('\\', '\\\\'):gsub('<', '\\<')))
ret.lhs = lhs
+ ret.lhsraw = lhsraw
+ ret.lhsrawalt = lhsrawalt ~= lhsraw and lhsrawalt or nil
ret.rhs = rhs
ret.mode = mode
ret.mode_bits = mode_bits_map[mode]
@@ -339,16 +343,6 @@ describe('nvim_get_keymap', function()
command('onoremap \\<C-a><C-a><LT>C-a>\\ \\<C-b><C-b><LT>C-b>\\')
command('onoremap <special> \\<C-c><C-c><LT>C-c>\\ \\<C-d><C-d><LT>C-d>\\')
- -- wrapper around get_keymap() that drops "lhsraw" and "lhsrawalt" which are hard to check
- local function get_keymap_noraw(...)
- local ret = api.nvim_get_keymap(...)
- for _, item in ipairs(ret) do
- item.lhsraw = nil
- item.lhsrawalt = nil
- end
- return ret
- end
-
for _, cmd in ipairs({
'set cpo-=B',
'set cpo+=B',
@@ -357,19 +351,19 @@ describe('nvim_get_keymap', function()
eq({
cpomap('\\<C-C><C-C><lt>C-c>\\', '\\<C-D><C-D><lt>C-d>\\', 'n'),
cpomap('\\<C-A><C-A><lt>C-a>\\', '\\<C-B><C-B><lt>C-b>\\', 'n'),
- }, get_keymap_noraw('n'))
+ }, api.nvim_get_keymap('n'))
eq({
cpomap('\\<C-C><C-C><lt>C-c>\\', '\\<C-D><C-D><lt>C-d>\\', 'x'),
cpomap('\\<C-A><C-A><lt>C-a>\\', '\\<C-B><C-B><lt>C-b>\\', 'x'),
- }, get_keymap_noraw('x'))
+ }, api.nvim_get_keymap('x'))
eq({
cpomap('<lt>C-c><C-C><lt>C-c> ', '<lt>C-d><C-D><lt>C-d>', 's'),
cpomap('<lt>C-a><C-A><lt>C-a> ', '<lt>C-b><C-B><lt>C-b>', 's'),
- }, get_keymap_noraw('s'))
+ }, api.nvim_get_keymap('s'))
eq({
cpomap('<lt>C-c><C-C><lt>C-c> ', '<lt>C-d><C-D><lt>C-d>', 'o'),
cpomap('<lt>C-a><C-A><lt>C-a> ', '<lt>C-b><C-B><lt>C-b>', 'o'),
- }, get_keymap_noraw('o'))
+ }, api.nvim_get_keymap('o'))
end
end)