mirror of
https://github.com/neovim/neovim.git
synced 2025-09-06 03:18:16 +00:00
Merge pull request #34828 from ncrpy/fix-get_keymap-lhsrawalt
fix(api): populate `lhsrawalt` in `nvim_get_keymap` response
This commit is contained in:
@@ -2894,7 +2894,10 @@ ArrayOf(Dict) keymap_array(String mode, buf_T *buf, Arena *arena)
|
|||||||
}
|
}
|
||||||
// Check for correct mode
|
// Check for correct mode
|
||||||
if (int_mode & current_maphash->m_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)));
|
is_abbrev, false, arena)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -316,7 +316,11 @@ describe('nvim_get_keymap', function()
|
|||||||
}
|
}
|
||||||
local function cpomap(lhs, rhs, mode)
|
local function cpomap(lhs, rhs, mode)
|
||||||
local ret = shallowcopy(cpo_table)
|
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.lhs = lhs
|
||||||
|
ret.lhsraw = lhsraw
|
||||||
|
ret.lhsrawalt = lhsrawalt ~= lhsraw and lhsrawalt or nil
|
||||||
ret.rhs = rhs
|
ret.rhs = rhs
|
||||||
ret.mode = mode
|
ret.mode = mode
|
||||||
ret.mode_bits = mode_bits_map[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 \\<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>\\')
|
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({
|
for _, cmd in ipairs({
|
||||||
'set cpo-=B',
|
'set cpo-=B',
|
||||||
'set cpo+=B',
|
'set cpo+=B',
|
||||||
@@ -357,19 +351,19 @@ describe('nvim_get_keymap', function()
|
|||||||
eq({
|
eq({
|
||||||
cpomap('\\<C-C><C-C><lt>C-c>\\', '\\<C-D><C-D><lt>C-d>\\', 'n'),
|
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'),
|
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({
|
eq({
|
||||||
cpomap('\\<C-C><C-C><lt>C-c>\\', '\\<C-D><C-D><lt>C-d>\\', 'x'),
|
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'),
|
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({
|
eq({
|
||||||
cpomap('<lt>C-c><C-C><lt>C-c> ', '<lt>C-d><C-D><lt>C-d>', 's'),
|
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'),
|
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({
|
eq({
|
||||||
cpomap('<lt>C-c><C-C><lt>C-c> ', '<lt>C-d><C-D><lt>C-d>', 'o'),
|
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'),
|
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
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user