mirror of
https://github.com/NotAShelf/neovim-flake.git
synced 2025-01-25 11:49:48 +01:00
105 lines
3.1 KiB
Nix
105 lines
3.1 KiB
Nix
{
|
|
lib,
|
|
config,
|
|
...
|
|
}: let
|
|
inherit (lib.modules) mkIf mkDefault;
|
|
inherit (lib.strings) optionalString;
|
|
inherit (lib.generators) mkLuaInline;
|
|
inherit (lib.nvim.lua) toLuaObject;
|
|
inherit (builtins) concatStringsSep typeOf tryEval attrNames mapAttrs;
|
|
|
|
cfg = config.vim.autocomplete.blink-cmp;
|
|
autocompleteCfg = config.vim.autocomplete;
|
|
inherit (cfg) mappings;
|
|
|
|
getPluginName = plugin:
|
|
if typeOf plugin == "string"
|
|
then plugin
|
|
else if (plugin ? pname && (tryEval plugin.pname).success)
|
|
then plugin.pname
|
|
else plugin.name;
|
|
in {
|
|
vim = mkIf cfg.enable {
|
|
startPlugins = ["blink-compat"];
|
|
lazy.plugins = {
|
|
blink-cmp = {
|
|
package = "blink-cmp";
|
|
setupModule = "blink.cmp";
|
|
inherit (cfg) setupOpts;
|
|
|
|
# TODO: lazy disabled until lspconfig is lazy loaded
|
|
#
|
|
# event = ["InsertEnter" "CmdlineEnter"];
|
|
|
|
after = ''
|
|
${optionalString config.vim.lazy.enable
|
|
(concatStringsSep "\n" (map
|
|
(package: "require('lz.n').trigger_load(${toLuaObject (getPluginName package)})")
|
|
autocompleteCfg.sourcePlugins))}
|
|
'';
|
|
};
|
|
};
|
|
|
|
autocomplete = {
|
|
enableSharedCmpSources = true;
|
|
|
|
blink-cmp.setupOpts = {
|
|
sources = {
|
|
default = mkDefault (attrNames autocompleteCfg.nvim-cmp.sources);
|
|
providers =
|
|
mapAttrs (name: _: {
|
|
inherit name;
|
|
module = "blink.compat.source";
|
|
})
|
|
autocompleteCfg.nvim-cmp.sources;
|
|
};
|
|
snippets = mkIf config.vim.snippets.luasnip.enable {
|
|
expand = mkLuaInline ''
|
|
function(snippet)
|
|
return require("luasnip").lsp_expand(snippet)
|
|
end
|
|
'';
|
|
active = mkLuaInline ''
|
|
function(filter)
|
|
if filter and filter.direction then
|
|
return require('luasnip').jumpable(filter.direction)
|
|
end
|
|
return require('luasnip').in_snippet()
|
|
end
|
|
'';
|
|
jump = mkLuaInline "function(direction) require('luasnip').jump(direction) end";
|
|
};
|
|
|
|
keymap = {
|
|
${mappings.complete} = ["show" "fallback"];
|
|
${mappings.close} = ["hide" "fallback"];
|
|
${mappings.scrollDocsUp} = ["scroll_documentation_up" "fallback"];
|
|
${mappings.scrollDocsDown} = ["scroll_documentation_down" "fallback"];
|
|
${mappings.confirm} = ["accept" "fallback"];
|
|
|
|
${mappings.next} = [
|
|
"select_next"
|
|
"snippet_forward"
|
|
(mkLuaInline ''
|
|
function(cmp)
|
|
local line, col = unpack(vim.api.nvim_win_get_cursor(0))
|
|
has_words_before = col ~= 0 and vim.api.nvim_buf_get_lines(0, line - 1, line, true)[1]:sub(col, col):match("%s") == nil
|
|
|
|
if has_words_before then
|
|
return cmp.show()
|
|
end
|
|
end
|
|
'')
|
|
"fallback"
|
|
];
|
|
${mappings.previous} = [
|
|
"select_prev"
|
|
"snippet_backward"
|
|
"fallback"
|
|
];
|
|
};
|
|
};
|
|
};
|
|
};
|
|
}
|