Support vim-endwise

This commit is contained in:
hrsh7th
2021-09-08 19:25:02 +09:00
parent fa031530ed
commit 8f559af081
2 changed files with 22 additions and 9 deletions

View File

@@ -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)