Support vim-endwise
This commit is contained in:
@@ -57,6 +57,7 @@ keymap.feedkeys = setmetatable({
|
||||
if #keys ~= 0 then
|
||||
vim.api.nvim_feedkeys(keys, mode, true)
|
||||
end
|
||||
|
||||
if callback then
|
||||
if vim.fn.reg_recording() == '' then
|
||||
local id = misc.id('cmp.utils.keymap.feedkeys')
|
||||
@@ -141,13 +142,24 @@ misc.set(_G, { 'cmp', 'utils', 'keymap', 'listen', 'run' }, function(mode, keys)
|
||||
local existing = keymap.listen.cache:get({ mode, bufnr, keys }).existing
|
||||
local callback = keymap.listen.cache:get({ mode, bufnr, keys }).callback
|
||||
callback(keys, function()
|
||||
vim.api.nvim_buf_set_keymap(0, mode, '<Plug>(cmp-utils-keymap-listen-run:_)', existing.rhs, {
|
||||
expr = existing.expr ~= 0,
|
||||
noremap = existing.noremap ~= 0,
|
||||
script = existing.script ~= 0,
|
||||
silent = true,
|
||||
})
|
||||
vim.fn.feedkeys(keymap.t('<Plug>(cmp-utils-keymap-listen-run:_)'), '')
|
||||
if existing.expr == 1 or existing.script == 1 then
|
||||
vim.api.nvim_buf_set_keymap(0, mode, '<Plug>(cmp-utils-keymap-listen-run:_)', existing.rhs, {
|
||||
expr = existing.expr ~= 0,
|
||||
noremap = existing.noremap ~= 0,
|
||||
script = existing.script ~= 0,
|
||||
silent = true,
|
||||
})
|
||||
keymap.feedkeys(keymap.t('<Plug>(cmp-utils-keymap-listen-run:_)'), '')
|
||||
elseif existing.noremap == 1 then
|
||||
keymap.feedkeys(keymap.t(keys), 'n')
|
||||
else
|
||||
for i, keys_ in ipairs(vim.split(existing.rhs, existing.lhs, true)) do
|
||||
if i ~= 1 then
|
||||
keymap.feedkeys(keymap.t(existing.lhs), 'n')
|
||||
end
|
||||
keymap.feedkeys(keymap.t(keys_), '')
|
||||
end
|
||||
end
|
||||
end)
|
||||
return keymap.t('<Ignore>')
|
||||
end)
|
||||
|
||||
Reference in New Issue
Block a user