This commit is contained in:
hrsh7th
2021-10-16 13:27:36 +09:00
parent 5fe7dc1eea
commit ebe040b1a9
7 changed files with 32 additions and 21 deletions

View File

@@ -38,7 +38,7 @@ context.new = function(prev_context, option)
option = option or {} option = option or {}
local self = setmetatable({}, { __index = context }) local self = setmetatable({}, { __index = context })
self.id = misc.id('context') self.id = misc.id('cmp.context.new')
self.cache = cache.new() self.cache = cache.new()
self.prev_context = prev_context or context.empty() self.prev_context = prev_context or context.empty()
self.option = option or { reason = types.cmp.ContextReason.None } self.option = option or { reason = types.cmp.ContextReason.None }

View File

@@ -32,7 +32,7 @@ local entry = {}
---@return cmp.Entry ---@return cmp.Entry
entry.new = function(ctx, source, completion_item) entry.new = function(ctx, source, completion_item)
local self = setmetatable({}, { __index = entry }) local self = setmetatable({}, { __index = entry })
self.id = misc.id('entry') self.id = misc.id('entry.new')
self.cache = cache.new() self.cache = cache.new()
self.match_cache = cache.new() self.match_cache = cache.new()
self.score = 0 self.score = 0

View File

@@ -34,7 +34,7 @@ source.SourceStatus.COMPLETED = 3
---@return cmp.Source ---@return cmp.Source
source.new = function(name, s) source.new = function(name, s)
local self = setmetatable({}, { __index = source }) local self = setmetatable({}, { __index = source })
self.id = misc.id('source') self.id = misc.id('cmp.source.new')
self.name = name self.name = name
self.source = s self.source = s
self.cache = cache.new() self.cache = cache.new()

View File

@@ -136,46 +136,42 @@ end)
keymap.listen = setmetatable({ keymap.listen = setmetatable({
cache = cache.new(), cache = cache.new(),
}, { }, {
__call = function(self, mode, keys, callback) __call = function(self, mode, keys_or_chars, callback)
keys = keymap.to_keymap(keys) local keys = keymap.to_keymap(keys_or_chars)
local bufnr = vim.api.nvim_get_current_buf() local bufnr = vim.api.nvim_get_current_buf()
local existing = keymap.find_map_by_lhs(mode, keys) local existing = keymap.find_map_by_lhs(mode, keys)
local done = true local done = true
done = done and string.match(existing.rhs, vim.pesc('v:lua.cmp.utils.keymap.listen.run')) done = done and string.match(existing.rhs, vim.pesc('v:lua.cmp.utils.keymap.listen.run'))
done = done and self.cache:get({ mode, bufnr, keys }) ~= nil done = done and self.cache:get({ 'id', mode, bufnr, keys }) ~= nil
if done then if done then
return return
end end
self.cache:set({ 'id', mode, bufnr, keys }, misc.id('cmp.utils.keymap.listen'))
local fallback = keymap.evacuate(mode, keys) local fallback = keymap.evacuate(mode, keys)
vim.api.nvim_buf_set_keymap(0, mode, keys, ('<Cmd>call v:lua.cmp.utils.keymap.listen.run("%s", "%s")<CR>'):format(mode, str.escape(keymap.escape(keys), { '"' })), { vim.api.nvim_buf_set_keymap(0, mode, keys, ('<Cmd>call v:lua.cmp.utils.keymap.listen.run(%s)<CR>'):format(self.cache:get({ 'id', mode, bufnr, keys })), {
expr = false, expr = false,
noremap = true, noremap = true,
silent = true, silent = true,
nowait = true, nowait = true,
}) })
self.cache:set({ mode, bufnr, keys }, { self.cache:set({ 'definition', self.cache:get({ 'id', mode, bufnr, keys }) }, {
keys = keys,
mode = mode, mode = mode,
bufnr = bufnr,
callback = callback, callback = callback,
fallback = fallback, fallback = fallback,
existing = existing, existing = existing,
}) })
end, end,
}) })
misc.set(_G, { 'cmp', 'utils', 'keymap', 'listen', 'run' }, function(mode, keys) misc.set(_G, { 'cmp', 'utils', 'keymap', 'listen', 'run' }, function(id)
local bufnr = vim.api.nvim_get_current_buf() local definition = keymap.listen.cache:get({ 'definition', id })
local fallback = keymap.listen.cache:get({ mode, bufnr, keys }).fallback definition.callback(definition.keys, misc.once(function()
local callback = keymap.listen.cache:get({ mode, bufnr, keys }).callback keymap.feedkeys(keymap.t(definition.fallback), 'i')
local done = false end))
callback(keys, function()
if not done then
done = true
keymap.feedkeys(keymap.t(fallback), 'i')
end
end)
return keymap.t('<Ignore>') return keymap.t('<Ignore>')
end) end)

View File

@@ -1,5 +1,19 @@
local misc = {} local misc = {}
---Create once callback
---@param callback function
---@return function
misc.once = function(callback)
local done = false
return function()
if done then
return
end
done = true
callback()
end
end
---Return concatenated list ---Return concatenated list
---@param list1 any[] ---@param list1 any[]
---@param list2 any[] ---@param list2 any[]

View File

@@ -25,5 +25,6 @@ describe('utils.str', function()
assert.are.equal(str.escape('plain\\', {}), 'plain\\\\') assert.are.equal(str.escape('plain\\', {}), 'plain\\\\')
assert.are.equal(str.escape('plain\\"', {}), 'plain\\\\"') assert.are.equal(str.escape('plain\\"', {}), 'plain\\\\"')
assert.are.equal(str.escape('pla"in', { '"' }), 'pla\\"in') assert.are.equal(str.escape('pla"in', { '"' }), 'pla\\"in')
assert.are.equal(str.escape('call("")', { '"' }), 'call(\\"\\")')
end) end)
end) end)

View File

@@ -24,7 +24,7 @@ local window = {}
---@return cmp.Window ---@return cmp.Window
window.new = function() window.new = function()
local self = setmetatable({}, { __index = window }) local self = setmetatable({}, { __index = window })
self.name = misc.id('cmp.utils.window') self.name = misc.id('cmp.utils.window.new')
self.win = nil self.win = nil
self.swin1 = nil self.swin1 = nil
self.swin2 = nil self.swin2 = nil