From 05e5f5e3995403b7ab5a6b18a987c34b4c4e880a Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 01:24:06 +0100 Subject: [PATCH 01/19] blink: init --- .../completion/blink-cmp/blink-cmp.nix | 16 ++++++++++++++++ .../plugins/completion/blink-cmp/config.nix | 19 +++++++++++++++++++ .../plugins/completion/blink-cmp/default.nix | 3 +++ modules/plugins/completion/default.nix | 1 + modules/plugins/completion/options.nix | 7 +++++++ 5 files changed, 46 insertions(+) create mode 100644 modules/plugins/completion/blink-cmp/blink-cmp.nix create mode 100644 modules/plugins/completion/blink-cmp/config.nix create mode 100644 modules/plugins/completion/blink-cmp/default.nix create mode 100644 modules/plugins/completion/options.nix diff --git a/modules/plugins/completion/blink-cmp/blink-cmp.nix b/modules/plugins/completion/blink-cmp/blink-cmp.nix new file mode 100644 index 00000000..65abbdf9 --- /dev/null +++ b/modules/plugins/completion/blink-cmp/blink-cmp.nix @@ -0,0 +1,16 @@ +{lib, ...}: let + inherit (lib.options) mkEnableOption mkOption; + inherit (lib.types) listOf string; + inherit (lib.nvim.types) mkPluginSetupOption; +in { + options.vim.autocomplete.blink-cmp = { + enable = mkEnableOption "blink.cmp"; + setupOpts = mkPluginSetupOption "blink.cmp" { + sources = mkOption { + type = listOf string; + description = "List of sources to enable for completion."; + default = ["lsp" "path" "snippets" "buffer"]; + }; + }; + }; +} diff --git a/modules/plugins/completion/blink-cmp/config.nix b/modules/plugins/completion/blink-cmp/config.nix new file mode 100644 index 00000000..15391a24 --- /dev/null +++ b/modules/plugins/completion/blink-cmp/config.nix @@ -0,0 +1,19 @@ +{ + lib, + config, + ... +}: let + inherit (lib.modules) mkIf; + cfg = config.vim.autocomplete.blink-nvim; +in { + vim = mkIf cfg.enable { + lazy.plugins = [ + { + package = "blink-cmp"; + setupModule = "blink"; + inherit (cfg) setupOpts; + event = ["InsertEnter" "CmdlineEnter"]; + } + ]; + }; +} diff --git a/modules/plugins/completion/blink-cmp/default.nix b/modules/plugins/completion/blink-cmp/default.nix new file mode 100644 index 00000000..b781f3f6 --- /dev/null +++ b/modules/plugins/completion/blink-cmp/default.nix @@ -0,0 +1,3 @@ +{ + imports = [./blink-cmp.nix ./config.nix]; +} diff --git a/modules/plugins/completion/default.nix b/modules/plugins/completion/default.nix index 0cae45f6..0c0a61a0 100644 --- a/modules/plugins/completion/default.nix +++ b/modules/plugins/completion/default.nix @@ -1,5 +1,6 @@ { imports = [ ./nvim-cmp + ./blink-cmp ]; } diff --git a/modules/plugins/completion/options.nix b/modules/plugins/completion/options.nix new file mode 100644 index 00000000..b919b8ae --- /dev/null +++ b/modules/plugins/completion/options.nix @@ -0,0 +1,7 @@ +{lib, ...}: let + inherit (lib.options) mkEnableOption; +in { + options.vim.autocomplete = { + enableSharedCmpSources = mkEnableOption "cmp sources that can work in nvim-cmp and blink.cmp"; + }; +} From cb136a9485ac90f93ffbc84869f2be17f049f399 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 02:00:47 +0100 Subject: [PATCH 02/19] cmp: move source plugin into parent option --- modules/plugins/completion/config.nix | 34 +++++++++ modules/plugins/completion/default.nix | 3 + .../plugins/completion/nvim-cmp/config.nix | 70 ++++++++----------- .../plugins/completion/nvim-cmp/nvim-cmp.nix | 10 +-- modules/plugins/completion/options.nix | 12 +++- 5 files changed, 77 insertions(+), 52 deletions(-) create mode 100644 modules/plugins/completion/config.nix diff --git a/modules/plugins/completion/config.nix b/modules/plugins/completion/config.nix new file mode 100644 index 00000000..809dc3af --- /dev/null +++ b/modules/plugins/completion/config.nix @@ -0,0 +1,34 @@ +{ + lib, + config, + ... +}: let + inherit (builtins) typeOf tryEval; + inherit (lib.modules) mkIf; + inherit (lib.nvim.attrsets) mapListToAttrs; + cfg = config.vim.autocomplete; + + 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.enableSharedCmpSources { + startPlugins = ["rtp-nvim"]; + lazy.plugins = + mapListToAttrs (package: { + name = getPluginName package; + value = { + inherit package; + lazy = true; + after = '' + local path = vim.fn.globpath(vim.o.packpath, 'pack/*/opt/${getPluginName package}') + require("rtp_nvim").source_after_plugin_dir(path) + ''; + }; + }) + cfg.sourcePlugins; + }; +} diff --git a/modules/plugins/completion/default.nix b/modules/plugins/completion/default.nix index 0c0a61a0..2695606c 100644 --- a/modules/plugins/completion/default.nix +++ b/modules/plugins/completion/default.nix @@ -1,5 +1,8 @@ { imports = [ + ./config.nix + ./options.nix + ./nvim-cmp ./blink-cmp ]; diff --git a/modules/plugins/completion/nvim-cmp/config.nix b/modules/plugins/completion/nvim-cmp/config.nix index cfd3e53a..62f6c7d4 100644 --- a/modules/plugins/completion/nvim-cmp/config.nix +++ b/modules/plugins/completion/nvim-cmp/config.nix @@ -3,11 +3,10 @@ config, ... }: let - inherit (lib.modules) mkIf mkMerge; + inherit (lib.modules) mkIf; inherit (lib.strings) optionalString; inherit (lib.generators) mkLuaInline; inherit (lib.nvim.lua) toLuaObject; - inherit (lib.nvim.attrsets) mapListToAttrs; inherit (builtins) attrNames typeOf tryEval concatStringsSep; borders = config.vim.ui.borders.plugins.nvim-cmp; @@ -24,52 +23,39 @@ in { config = mkIf cfg.enable { vim = { - startPlugins = ["rtp-nvim"]; - lazy.plugins = mkMerge [ - (mapListToAttrs (package: { - name = getPluginName package; - value = { - inherit package; - lazy = true; - after = '' - local path = vim.fn.globpath(vim.o.packpath, 'pack/*/opt/${getPluginName package}') - require("rtp_nvim").source_after_plugin_dir(path) - ''; - }; - }) - cfg.sourcePlugins) - { - nvim-cmp = { - package = "nvim-cmp"; - after = '' - ${optionalString luasnipEnable "local luasnip = require('luasnip')"} - local cmp = require("cmp") + autocomplete.enableSharedCmpSources = true; - local kinds = require("cmp.types").lsp.CompletionItemKind - local deprio = function(kind) - return function(e1, e2) - if e1:get_kind() == kind then - return false - end - if e2:get_kind() == kind then - return true - end - return nil + lazy.plugins = { + nvim-cmp = { + package = "nvim-cmp"; + after = '' + ${optionalString luasnipEnable "local luasnip = require('luasnip')"} + local cmp = require("cmp") + + local kinds = require("cmp.types").lsp.CompletionItemKind + local deprio = function(kind) + return function(e1, e2) + if e1:get_kind() == kind then + return false end + if e2:get_kind() == kind then + return true + end + return nil end + end - cmp.setup(${toLuaObject cfg.setupOpts}) + cmp.setup(${toLuaObject cfg.setupOpts}) - ${optionalString config.vim.lazy.enable - (concatStringsSep "\n" (map - (package: "require('lz.n').trigger_load(${toLuaObject (getPluginName package)})") - cfg.sourcePlugins))} - ''; + ${optionalString config.vim.lazy.enable + (concatStringsSep "\n" (map + (package: "require('lz.n').trigger_load(${toLuaObject (getPluginName package)})") + cfg.sourcePlugins))} + ''; - event = ["InsertEnter" "CmdlineEnter"]; - }; - } - ]; + event = ["InsertEnter" "CmdlineEnter"]; + }; + }; autocomplete.nvim-cmp = { sources = { diff --git a/modules/plugins/completion/nvim-cmp/nvim-cmp.nix b/modules/plugins/completion/nvim-cmp/nvim-cmp.nix index 0c790455..00e8c056 100644 --- a/modules/plugins/completion/nvim-cmp/nvim-cmp.nix +++ b/modules/plugins/completion/nvim-cmp/nvim-cmp.nix @@ -4,10 +4,10 @@ ... }: let inherit (lib.options) mkEnableOption mkOption literalExpression literalMD; - inherit (lib.types) str attrsOf nullOr either listOf; + inherit (lib.types) str attrsOf nullOr either; inherit (lib.generators) mkLuaInline; inherit (lib.nvim.binds) mkMappingOption; - inherit (lib.nvim.types) mkPluginSetupOption luaInline mergelessListOf pluginType; + inherit (lib.nvim.types) mkPluginSetupOption luaInline mergelessListOf; inherit (lib.nvim.lua) toLuaObject; inherit (builtins) isString; @@ -107,11 +107,5 @@ in { } ''; }; - - sourcePlugins = mkOption { - type = listOf pluginType; - default = []; - description = "List of source plugins used by nvim-cmp."; - }; }; } diff --git a/modules/plugins/completion/options.nix b/modules/plugins/completion/options.nix index b919b8ae..4066ddf9 100644 --- a/modules/plugins/completion/options.nix +++ b/modules/plugins/completion/options.nix @@ -1,7 +1,15 @@ {lib, ...}: let - inherit (lib.options) mkEnableOption; + inherit (lib.options) mkEnableOption mkOption; + inherit (lib.types) listOf; + inherit (lib.nvim.types) pluginType; in { options.vim.autocomplete = { - enableSharedCmpSources = mkEnableOption "cmp sources that can work in nvim-cmp and blink.cmp"; + enableSharedCmpSources = mkEnableOption "cmp sources shared by nvim-cmp and blink.cmp"; + + cmpSourcePlugins = mkOption { + type = listOf pluginType; + default = []; + description = "List of cmp source plugins."; + }; }; } From 6e3c9cbc1e768426aac432e923bc4c233079df1f Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 02:48:03 +0100 Subject: [PATCH 03/19] completion: migrate to shared cmp source options --- modules/plugins/assistant/copilot/config.nix | 4 +- .../plugins/completion/nvim-cmp/config.nix | 114 +++++++++--------- modules/plugins/completion/options.nix | 2 +- modules/plugins/lsp/config.nix | 9 +- modules/plugins/lsp/lspkind/config.nix | 3 +- modules/plugins/notes/obsidian/obsidian.nix | 2 +- modules/plugins/snippets/luasnip/config.nix | 4 +- modules/plugins/treesitter/config.nix | 4 +- 8 files changed, 75 insertions(+), 67 deletions(-) diff --git a/modules/plugins/assistant/copilot/config.nix b/modules/plugins/assistant/copilot/config.nix index 37da046f..1a070fe3 100644 --- a/modules/plugins/assistant/copilot/config.nix +++ b/modules/plugins/assistant/copilot/config.nix @@ -58,8 +58,8 @@ in { }; }; - autocomplete.nvim-cmp = { - sources = {copilot = "[Copilot]";}; + autocomplete = { + nvim-cmp.sources = {copilot = "[Copilot]";}; sourcePlugins = ["copilot-cmp"]; }; diff --git a/modules/plugins/completion/nvim-cmp/config.nix b/modules/plugins/completion/nvim-cmp/config.nix index 62f6c7d4..7745cb21 100644 --- a/modules/plugins/completion/nvim-cmp/config.nix +++ b/modules/plugins/completion/nvim-cmp/config.nix @@ -12,6 +12,7 @@ borders = config.vim.ui.borders.plugins.nvim-cmp; cfg = config.vim.autocomplete.nvim-cmp; + autocompleteCfg = config.vim.autocomplete; luasnipEnable = config.vim.snippets.luasnip.enable; getPluginName = plugin: if typeOf plugin == "string" @@ -23,8 +24,6 @@ in { config = mkIf cfg.enable { vim = { - autocomplete.enableSharedCmpSources = true; - lazy.plugins = { nvim-cmp = { package = "nvim-cmp"; @@ -50,74 +49,77 @@ in { ${optionalString config.vim.lazy.enable (concatStringsSep "\n" (map (package: "require('lz.n').trigger_load(${toLuaObject (getPluginName package)})") - cfg.sourcePlugins))} + autocompleteCfg.sourcePlugins))} ''; event = ["InsertEnter" "CmdlineEnter"]; }; }; - autocomplete.nvim-cmp = { - sources = { - nvim-cmp = null; - buffer = "[Buffer]"; - path = "[Path]"; - }; - + autocomplete = { + enableSharedCmpSources = true; sourcePlugins = ["cmp-buffer" "cmp-path"]; - setupOpts = { - sources = map (s: {name = s;}) (attrNames cfg.sources); - - window = mkIf borders.enable { - completion.border = borders.style; - documentation.border = borders.style; + nvim-cmp = { + sources = { + nvim-cmp = null; + buffer = "[Buffer]"; + path = "[Path]"; }; - formatting.format = cfg.format; + setupOpts = { + sources = map (s: {name = s;}) (attrNames cfg.sources); - # `cmp` and `luasnip` are defined above, in the `nvim-cmp` section - mapping = { - ${mappings.complete} = mkLuaInline "cmp.mapping.complete()"; - ${mappings.close} = mkLuaInline "cmp.mapping.abort()"; - ${mappings.scrollDocsUp} = mkLuaInline "cmp.mapping.scroll_docs(-4)"; - ${mappings.scrollDocsDown} = mkLuaInline "cmp.mapping.scroll_docs(4)"; - ${mappings.confirm} = mkLuaInline "cmp.mapping.confirm({ select = true })"; + window = mkIf borders.enable { + completion.border = borders.style; + documentation.border = borders.style; + }; - ${mappings.next} = mkLuaInline '' - cmp.mapping(function(fallback) - local has_words_before = function() - local line, col = unpack(vim.api.nvim_win_get_cursor(0)) - return col ~= 0 and vim.api.nvim_buf_get_lines(0, line - 1, line, true)[1]:sub(col, col):match("%s") == nil - end + formatting.format = cfg.format; - if cmp.visible() then - cmp.select_next_item() - ${optionalString luasnipEnable '' - elseif luasnip.locally_jumpable(1) then - luasnip.jump(1) - ''} - elseif has_words_before() then - cmp.complete() - else - fallback() - end - end) - ''; + # `cmp` and `luasnip` are defined above, in the `nvim-cmp` section + mapping = { + ${mappings.complete} = mkLuaInline "cmp.mapping.complete()"; + ${mappings.close} = mkLuaInline "cmp.mapping.abort()"; + ${mappings.scrollDocsUp} = mkLuaInline "cmp.mapping.scroll_docs(-4)"; + ${mappings.scrollDocsDown} = mkLuaInline "cmp.mapping.scroll_docs(4)"; + ${mappings.confirm} = mkLuaInline "cmp.mapping.confirm({ select = true })"; - ${mappings.previous} = mkLuaInline '' - cmp.mapping(function(fallback) - if cmp.visible() then - cmp.select_prev_item() - ${optionalString luasnipEnable '' - elseif luasnip.locally_jumpable(-1) then - luasnip.jump(-1) - ''} - else - fallback() - end - end) - ''; + ${mappings.next} = mkLuaInline '' + cmp.mapping(function(fallback) + local has_words_before = function() + local line, col = unpack(vim.api.nvim_win_get_cursor(0)) + return col ~= 0 and vim.api.nvim_buf_get_lines(0, line - 1, line, true)[1]:sub(col, col):match("%s") == nil + end + + if cmp.visible() then + cmp.select_next_item() + ${optionalString luasnipEnable '' + elseif luasnip.locally_jumpable(1) then + luasnip.jump(1) + ''} + elseif has_words_before() then + cmp.complete() + else + fallback() + end + end) + ''; + + ${mappings.previous} = mkLuaInline '' + cmp.mapping(function(fallback) + if cmp.visible() then + cmp.select_prev_item() + ${optionalString luasnipEnable '' + elseif luasnip.locally_jumpable(-1) then + luasnip.jump(-1) + ''} + else + fallback() + end + end) + ''; + }; }; }; }; diff --git a/modules/plugins/completion/options.nix b/modules/plugins/completion/options.nix index 4066ddf9..330fbaf4 100644 --- a/modules/plugins/completion/options.nix +++ b/modules/plugins/completion/options.nix @@ -6,7 +6,7 @@ in { options.vim.autocomplete = { enableSharedCmpSources = mkEnableOption "cmp sources shared by nvim-cmp and blink.cmp"; - cmpSourcePlugins = mkOption { + sourcePlugins = mkOption { type = listOf pluginType; default = []; description = "List of cmp source plugins."; diff --git a/modules/plugins/lsp/config.nix b/modules/plugins/lsp/config.nix index e73a5387..e0a6660f 100644 --- a/modules/plugins/lsp/config.nix +++ b/modules/plugins/lsp/config.nix @@ -11,6 +11,7 @@ cfg = config.vim.lsp; usingNvimCmp = config.vim.autocomplete.nvim-cmp.enable; + usingBlinkCmp = config.vim.autocomplete.blink-cmp.enable; self = import ./module.nix {inherit config lib pkgs;}; mappingDefinitions = self.options.vim.lsp.mappings; @@ -22,8 +23,8 @@ in { config = mkIf cfg.enable { vim = { - autocomplete.nvim-cmp = { - sources = {nvim_lsp = "[LSP]";}; + autocomplete = mkIf usingNvimCmp { + nvim-cmp.sources = {nvim_lsp = "[LSP]";}; sourcePlugins = ["cmp-nvim-lsp"]; }; @@ -170,6 +171,10 @@ in { }, } ''} + + ${optionalString usingBlinkCmp '' + -- TODO + ''} ''; }; }; diff --git a/modules/plugins/lsp/lspkind/config.nix b/modules/plugins/lsp/lspkind/config.nix index 2ef20ff8..bad67125 100644 --- a/modules/plugins/lsp/lspkind/config.nix +++ b/modules/plugins/lsp/lspkind/config.nix @@ -8,11 +8,12 @@ inherit (lib.nvim.lua) toLuaObject; cfg = config.vim.lsp.lspkind; + inherit (config.vim) autocomplete; in { config = mkIf cfg.enable { assertions = [ { - assertion = config.vim.autocomplete.nvim-cmp.enable; + assertion = autocomplete.nvim-cmp.enable || autocomplete.blink-cmp.enable; message = '' While lspkind supports Neovim's native lsp upstream, using that over nvim-cmp isn't recommended, nor supported by nvf. diff --git a/modules/plugins/notes/obsidian/obsidian.nix b/modules/plugins/notes/obsidian/obsidian.nix index 2dae5a9c..ca61583f 100644 --- a/modules/plugins/notes/obsidian/obsidian.nix +++ b/modules/plugins/notes/obsidian/obsidian.nix @@ -48,7 +48,7 @@ in { # If using nvim-cmp, otherwise set to false type = bool; description = "If using nvim-cmp, otherwise set to false"; - default = config.vim.autocomplete.nvim-cmp.enable; + default = config.vim.autocomplete.enableSharedCmpSources; }; }; }; diff --git a/modules/plugins/snippets/luasnip/config.nix b/modules/plugins/snippets/luasnip/config.nix index 927b21fd..2e5df6f5 100644 --- a/modules/plugins/snippets/luasnip/config.nix +++ b/modules/plugins/snippets/luasnip/config.nix @@ -17,8 +17,8 @@ in { }; }; startPlugins = cfg.providers; - autocomplete.nvim-cmp = { - sources = {luasnip = "[LuaSnip]";}; + autocomplete = { + nvim-cmp.sources = {luasnip = "[LuaSnip]";}; sourcePlugins = ["cmp-luasnip"]; }; }; diff --git a/modules/plugins/treesitter/config.nix b/modules/plugins/treesitter/config.nix index 566a716e..b7d8c177 100644 --- a/modules/plugins/treesitter/config.nix +++ b/modules/plugins/treesitter/config.nix @@ -20,8 +20,8 @@ in { vim = { startPlugins = ["nvim-treesitter"]; - autocomplete.nvim-cmp = { - sources = {treesitter = "[Treesitter]";}; + autocomplete = { + nvim-cmp.sources = {treesitter = "[Treesitter]";}; sourcePlugins = ["cmp-treesitter"]; }; From 8897e164ba5dfc1feb12de4afc15914188a4855d Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 02:48:28 +0100 Subject: [PATCH 04/19] flake: add plugin blink.cmp --- flake.lock | 17 +++++++++++++++++ flake.nix | 5 +++++ modules/default.nix | 31 +++++++++++++++++++++++++++++++ 3 files changed, 53 insertions(+) diff --git a/flake.lock b/flake.lock index 3275a12f..fe3eabea 100644 --- a/flake.lock +++ b/flake.lock @@ -188,6 +188,22 @@ "type": "github" } }, + "plugin-blink-cmp": { + "flake": false, + "locked": { + "lastModified": 1734880418, + "narHash": "sha256-jR9fvo+I51DKYQb+N3nFvQ50N+lvYzfFaQtrn7cxDu4=", + "owner": "saghen", + "repo": "blink.cmp", + "rev": "f93af0f486ada13e8c34f42c911788b9232b811f", + "type": "github" + }, + "original": { + "owner": "saghen", + "repo": "blink.cmp", + "type": "github" + } + }, "plugin-bufdelete-nvim": { "flake": false, "locked": { @@ -2076,6 +2092,7 @@ "nmd": "nmd", "plugin-alpha-nvim": "plugin-alpha-nvim", "plugin-base16": "plugin-base16", + "plugin-blink-cmp": "plugin-blink-cmp", "plugin-bufdelete-nvim": "plugin-bufdelete-nvim", "plugin-catppuccin": "plugin-catppuccin", "plugin-ccc": "plugin-ccc", diff --git a/flake.nix b/flake.nix index 161ba43f..f04e72cc 100644 --- a/flake.nix +++ b/flake.nix @@ -288,6 +288,11 @@ flake = false; }; + plugin-blink-cmp = { + url = "github:saghen/blink.cmp"; + flake = false; + }; + plugin-nvim-cmp = { url = "github:hrsh7th/nvim-cmp"; flake = false; diff --git a/modules/default.nix b/modules/default.nix index a2f8730d..b268f94f 100644 --- a/modules/default.nix +++ b/modules/default.nix @@ -72,6 +72,37 @@ pname = "flutter-tools"; patches = [../patches/flutter-tools.patch]; }; + blink-cmp = let + version = inputs.plugin-blink-cmp.shortRev or inputs.plugin-blink-cmp.shortDirtyRev or "dirty"; + src = inputs.plugin-blink-cmp; + blink-fuzzy-lib = pkgs.rustPlatform.buildRustPackage { + pname = "blink-fuzzy-lib"; + inherit version src; + + env = { + # TODO: remove this if plugin stops using nightly rust + RUSTC_BOOTSTRAP = true; + }; + cargoLock = { + lockFile = "${src}/Cargo.lock"; + outputHashes = { + "frizbee-0.1.0" = "sha256-pt6sMsRyjXrbrTK7t/YvWeen/n3nU8UUaiNYTY1LczE="; + }; + }; + }; + libExt = + if pkgs.hostPlatform.isDarwin + then "dylib" + else "so"; + in + buildPlug { + pname = "blink-cmp"; + inherit version src; + preInstall = '' + mkdir -p target/release + ln -s ${blink-fuzzy-lib}/lib/libblink_cmp_fuzzy.${libExt} target/release/libblink_cmp_fuzzy.${libExt} + ''; + }; }; buildConfigPlugins = plugins: From e280cdc8f390a7ba4d45b57585cc7d41fffb4931 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 02:51:21 +0100 Subject: [PATCH 05/19] blink: basic keymap option --- .../completion/blink-cmp/blink-cmp.nix | 36 +++++++++++++++---- 1 file changed, 29 insertions(+), 7 deletions(-) diff --git a/modules/plugins/completion/blink-cmp/blink-cmp.nix b/modules/plugins/completion/blink-cmp/blink-cmp.nix index 65abbdf9..8b1aeb9c 100644 --- a/modules/plugins/completion/blink-cmp/blink-cmp.nix +++ b/modules/plugins/completion/blink-cmp/blink-cmp.nix @@ -1,15 +1,37 @@ {lib, ...}: let - inherit (lib.options) mkEnableOption mkOption; - inherit (lib.types) listOf string; - inherit (lib.nvim.types) mkPluginSetupOption; + inherit (lib.options) mkEnableOption mkOption literalMD; + inherit (lib.types) listOf str either oneOf attrsOf; + inherit (lib.nvim.types) mkPluginSetupOption luaInline; in { options.vim.autocomplete.blink-cmp = { enable = mkEnableOption "blink.cmp"; setupOpts = mkPluginSetupOption "blink.cmp" { - sources = mkOption { - type = listOf string; - description = "List of sources to enable for completion."; - default = ["lsp" "path" "snippets" "buffer"]; + sources = { + default = mkOption { + type = listOf str; + description = "Default list of sources to enable for completion."; + default = ["lsp" "path" "snippets" "buffer"]; + }; + }; + + keymap = mkOption { + type = attrsOf (oneOf [luaInline str (listOf (either str luaInline))]); + default = {}; + description = "blink.cmp keymap"; + example = literalMD '' + ```nix + "" = ["select_prev" "fallback"]; + "" = [ + (lib.generators.mkLuaInline '''' + function(cmp) + if some_condition then return end -- runs the next command + return true -- doesn't run the next command + end, + '''') + "select_next" + ]; + ``` + ''; }; }; }; From e2de9a1e27c54711682baa7461b300aca5427770 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 02:51:53 +0100 Subject: [PATCH 06/19] blink: add luasnip integration --- .../plugins/completion/blink-cmp/config.nix | 40 ++++++++++++++----- 1 file changed, 31 insertions(+), 9 deletions(-) diff --git a/modules/plugins/completion/blink-cmp/config.nix b/modules/plugins/completion/blink-cmp/config.nix index 15391a24..663e19c5 100644 --- a/modules/plugins/completion/blink-cmp/config.nix +++ b/modules/plugins/completion/blink-cmp/config.nix @@ -4,16 +4,38 @@ ... }: let inherit (lib.modules) mkIf; - cfg = config.vim.autocomplete.blink-nvim; + inherit (lib.generators) mkLuaInline; + cfg = config.vim.autocomplete.blink-cmp; in { vim = mkIf cfg.enable { - lazy.plugins = [ - { - package = "blink-cmp"; - setupModule = "blink"; - inherit (cfg) setupOpts; - event = ["InsertEnter" "CmdlineEnter"]; - } - ]; + lazy.plugins.blink-cmp = { + package = "blink-cmp"; + setupModule = "blink.cmp"; + inherit (cfg) setupOpts; + event = ["InsertEnter" "CmdlineEnter"]; + }; + + autocomplete = { + enableSharedCmpSources = true; + + blink-cmp.setupOpts = { + 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"; + }; + }; + }; }; } From 63ea5bd71fe00bf67cab6f1785630700fc7d1bf8 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 03:59:57 +0100 Subject: [PATCH 07/19] blink: keymap wrapper --- .../completion/blink-cmp/blink-cmp.nix | 50 ++++++++++++++----- .../plugins/completion/blink-cmp/config.nix | 31 ++++++++++++ 2 files changed, 69 insertions(+), 12 deletions(-) diff --git a/modules/plugins/completion/blink-cmp/blink-cmp.nix b/modules/plugins/completion/blink-cmp/blink-cmp.nix index 8b1aeb9c..a55dd43d 100644 --- a/modules/plugins/completion/blink-cmp/blink-cmp.nix +++ b/modules/plugins/completion/blink-cmp/blink-cmp.nix @@ -1,7 +1,19 @@ {lib, ...}: let inherit (lib.options) mkEnableOption mkOption literalMD; - inherit (lib.types) listOf str either oneOf attrsOf; + inherit (lib.types) listOf str either attrsOf submodule enum; inherit (lib.nvim.types) mkPluginSetupOption luaInline; + inherit (lib.nvim.binds) mkMappingOption; + + keymapType = submodule { + freeformType = attrsOf (listOf (either str luaInline)); + options = { + preset = mkOption { + type = enum ["default" "none" "super-tab" "enter"]; + default = "none"; + description = "keymap presets"; + }; + }; + }; in { options.vim.autocomplete.blink-cmp = { enable = mkEnableOption "blink.cmp"; @@ -15,24 +27,38 @@ in { }; keymap = mkOption { - type = attrsOf (oneOf [luaInline str (listOf (either str luaInline))]); + type = keymapType; default = {}; description = "blink.cmp keymap"; example = literalMD '' ```nix - "" = ["select_prev" "fallback"]; - "" = [ - (lib.generators.mkLuaInline '''' - function(cmp) - if some_condition then return end -- runs the next command - return true -- doesn't run the next command - end, - '''') - "select_next" - ]; + vim.autocomplete.blink-cmp.setupOpts.keymap = { + preset = "none"; + + "" = ["select_prev" "fallback"]; + "" = [ + (lib.generators.mkLuaInline '''' + function(cmp) + if some_condition then return end -- runs the next command + return true -- doesn't run the next command + end, + '''') + "select_next" + ]; + }; ``` ''; }; }; + + mappings = { + complete = mkMappingOption "Complete [blink.cmp]" ""; + confirm = mkMappingOption "Confirm [blink.cmp]" ""; + next = mkMappingOption "Next item [blink.cmp]" ""; + previous = mkMappingOption "Previous item [blink.cmp]" ""; + close = mkMappingOption "Close [blink.cmp]" ""; + scrollDocsUp = mkMappingOption "Scroll docs up [blink.cmp]" ""; + scrollDocsDown = mkMappingOption "Scroll docs down [blink.cmp]" ""; + }; }; } diff --git a/modules/plugins/completion/blink-cmp/config.nix b/modules/plugins/completion/blink-cmp/config.nix index 663e19c5..233fff3d 100644 --- a/modules/plugins/completion/blink-cmp/config.nix +++ b/modules/plugins/completion/blink-cmp/config.nix @@ -5,7 +5,9 @@ }: let inherit (lib.modules) mkIf; inherit (lib.generators) mkLuaInline; + cfg = config.vim.autocomplete.blink-cmp; + inherit (cfg) mappings; in { vim = mkIf cfg.enable { lazy.plugins.blink-cmp = { @@ -35,6 +37,35 @@ in { ''; 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" + ]; + }; }; }; }; From ddabc26c337dfa1330795687584cedd0f845fbe0 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 04:02:08 +0100 Subject: [PATCH 08/19] lsp: use blink.cmp capabilities --- modules/plugins/lsp/config.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/plugins/lsp/config.nix b/modules/plugins/lsp/config.nix index e0a6660f..550f7cc7 100644 --- a/modules/plugins/lsp/config.nix +++ b/modules/plugins/lsp/config.nix @@ -173,7 +173,7 @@ in { ''} ${optionalString usingBlinkCmp '' - -- TODO + capabilities = require('blink.cmp').get_lsp_capabilities(capabilities) ''} ''; }; From 244a560922bedca96d2f6eae17b089b56bbc0e00 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 04:02:20 +0100 Subject: [PATCH 09/19] blink: disable lazy-loading --- modules/plugins/completion/blink-cmp/config.nix | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/modules/plugins/completion/blink-cmp/config.nix b/modules/plugins/completion/blink-cmp/config.nix index 233fff3d..50fe4563 100644 --- a/modules/plugins/completion/blink-cmp/config.nix +++ b/modules/plugins/completion/blink-cmp/config.nix @@ -14,7 +14,9 @@ in { package = "blink-cmp"; setupModule = "blink.cmp"; inherit (cfg) setupOpts; - event = ["InsertEnter" "CmdlineEnter"]; + # TODO: lazy disabled until lspconfig is lazy loaded + # + # event = ["InsertEnter" "CmdlineEnter"]; }; autocomplete = { From 9f6f191e0790dbb15d8112fe122bf6aa87b617af Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 19:06:19 +0100 Subject: [PATCH 10/19] flake: add blink.compat --- flake.lock | 17 +++++++++++++++++ flake.nix | 5 +++++ 2 files changed, 22 insertions(+) diff --git a/flake.lock b/flake.lock index fe3eabea..8dba5fd9 100644 --- a/flake.lock +++ b/flake.lock @@ -204,6 +204,22 @@ "type": "github" } }, + "plugin-blink-compat": { + "flake": false, + "locked": { + "lastModified": 1734896240, + "narHash": "sha256-Rrrh+O3FbBnaAnCHwPuQyfhH+XueSkQp6ipEkn6esGY=", + "owner": "saghen", + "repo": "blink.compat", + "rev": "74b251a1e9478c4fa6d7c6bc2921d7124e6f6cbb", + "type": "github" + }, + "original": { + "owner": "saghen", + "repo": "blink.compat", + "type": "github" + } + }, "plugin-bufdelete-nvim": { "flake": false, "locked": { @@ -2093,6 +2109,7 @@ "plugin-alpha-nvim": "plugin-alpha-nvim", "plugin-base16": "plugin-base16", "plugin-blink-cmp": "plugin-blink-cmp", + "plugin-blink-compat": "plugin-blink-compat", "plugin-bufdelete-nvim": "plugin-bufdelete-nvim", "plugin-catppuccin": "plugin-catppuccin", "plugin-ccc": "plugin-ccc", diff --git a/flake.nix b/flake.nix index f04e72cc..7aad3700 100644 --- a/flake.nix +++ b/flake.nix @@ -293,6 +293,11 @@ flake = false; }; + plugin-blink-compat = { + url = "github:saghen/blink.compat"; + flake = false; + }; + plugin-nvim-cmp = { url = "github:hrsh7th/nvim-cmp"; flake = false; From 1f8b49bcef50a4c46d1ab16eff07ba38ed2f835e Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 20:27:03 +0100 Subject: [PATCH 11/19] blink: add blink.compat support --- .../completion/blink-cmp/blink-cmp.nix | 18 ++++++- .../plugins/completion/blink-cmp/config.nix | 47 +++++++++++++++---- 2 files changed, 56 insertions(+), 9 deletions(-) diff --git a/modules/plugins/completion/blink-cmp/blink-cmp.nix b/modules/plugins/completion/blink-cmp/blink-cmp.nix index a55dd43d..7ca36f57 100644 --- a/modules/plugins/completion/blink-cmp/blink-cmp.nix +++ b/modules/plugins/completion/blink-cmp/blink-cmp.nix @@ -1,6 +1,6 @@ {lib, ...}: let inherit (lib.options) mkEnableOption mkOption literalMD; - inherit (lib.types) listOf str either attrsOf submodule enum; + inherit (lib.types) listOf str either attrsOf submodule enum anything; inherit (lib.nvim.types) mkPluginSetupOption luaInline; inherit (lib.nvim.binds) mkMappingOption; @@ -14,6 +14,16 @@ }; }; }; + + providerType = submodule { + freeformType = anything; + options = { + module = mkOption { + type = str; + description = "module of the provider"; + }; + }; + }; in { options.vim.autocomplete.blink-cmp = { enable = mkEnableOption "blink.cmp"; @@ -24,6 +34,12 @@ in { description = "Default list of sources to enable for completion."; default = ["lsp" "path" "snippets" "buffer"]; }; + + providers = mkOption { + type = attrsOf providerType; + description = "Providers"; + default = {}; + }; }; keymap = mkOption { diff --git a/modules/plugins/completion/blink-cmp/config.nix b/modules/plugins/completion/blink-cmp/config.nix index 50fe4563..295fbde2 100644 --- a/modules/plugins/completion/blink-cmp/config.nix +++ b/modules/plugins/completion/blink-cmp/config.nix @@ -3,26 +3,57 @@ config, ... }: let - inherit (lib.modules) mkIf; + 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 { - lazy.plugins.blink-cmp = { - package = "blink-cmp"; - setupModule = "blink.cmp"; - inherit (cfg) setupOpts; - # TODO: lazy disabled until lspconfig is lazy loaded - # - # event = ["InsertEnter" "CmdlineEnter"]; + 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) From 4fd2ded18a3c06bbe500c7dca2a156680730f576 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 20:27:27 +0100 Subject: [PATCH 12/19] treesitter-cmp: disable on blink.cmp --- modules/plugins/treesitter/config.nix | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/modules/plugins/treesitter/config.nix b/modules/plugins/treesitter/config.nix index b7d8c177..fcae3c5c 100644 --- a/modules/plugins/treesitter/config.nix +++ b/modules/plugins/treesitter/config.nix @@ -20,7 +20,8 @@ in { vim = { startPlugins = ["nvim-treesitter"]; - autocomplete = { + # cmp-treesitter doesn't work on blink.cmp + autocomplete = mkIf config.vim.autocomplete.nvim-cmp.enable { nvim-cmp.sources = {treesitter = "[Treesitter]";}; sourcePlugins = ["cmp-treesitter"]; }; From 57a6abc0631fabe8d5019bb94566523c6fea7507 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 20:32:48 +0100 Subject: [PATCH 13/19] blink: re-add default sources to cmp ones --- modules/plugins/completion/blink-cmp/config.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/plugins/completion/blink-cmp/config.nix b/modules/plugins/completion/blink-cmp/config.nix index 295fbde2..97f45fdb 100644 --- a/modules/plugins/completion/blink-cmp/config.nix +++ b/modules/plugins/completion/blink-cmp/config.nix @@ -46,7 +46,7 @@ in { blink-cmp.setupOpts = { sources = { - default = mkDefault (attrNames autocompleteCfg.nvim-cmp.sources); + default = ["lsp" "path" "snippets" "buffer"] ++ (attrNames autocompleteCfg.nvim-cmp.sources); providers = mapAttrs (name: _: { inherit name; From a0d75f91824ad654f46a472216ab8d643e2df804 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 20:45:17 +0100 Subject: [PATCH 14/19] blink: auto-show docs by default --- .../plugins/completion/blink-cmp/blink-cmp.nix | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/modules/plugins/completion/blink-cmp/blink-cmp.nix b/modules/plugins/completion/blink-cmp/blink-cmp.nix index 7ca36f57..5a374940 100644 --- a/modules/plugins/completion/blink-cmp/blink-cmp.nix +++ b/modules/plugins/completion/blink-cmp/blink-cmp.nix @@ -1,8 +1,9 @@ {lib, ...}: let inherit (lib.options) mkEnableOption mkOption literalMD; - inherit (lib.types) listOf str either attrsOf submodule enum anything; + inherit (lib.types) listOf str either attrsOf submodule enum anything int; inherit (lib.nvim.types) mkPluginSetupOption luaInline; inherit (lib.nvim.binds) mkMappingOption; + inherit (lib.nvim.config) mkBool; keymapType = submodule { freeformType = attrsOf (listOf (either str luaInline)); @@ -31,14 +32,25 @@ in { sources = { default = mkOption { type = listOf str; - description = "Default list of sources to enable for completion."; default = ["lsp" "path" "snippets" "buffer"]; + description = "Default list of sources to enable for completion."; }; providers = mkOption { type = attrsOf providerType; - description = "Providers"; default = {}; + description = "Providers"; + }; + }; + + completion = { + documentation = { + auto_show = mkBool true "Show documentation whenever an item is selected"; + auto_show_delay_ms = mkOption { + type = int; + default = 200; + description = "Delay before auto show triggers"; + }; }; }; From af67523642665c98b7f1eecd528a587b7cb08351 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 23 Dec 2024 23:20:22 +0100 Subject: [PATCH 15/19] docs: udpate release notes --- docs/release-notes/rl-0.8.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/docs/release-notes/rl-0.8.md b/docs/release-notes/rl-0.8.md index 567e4e6e..0ab868aa 100644 --- a/docs/release-notes/rl-0.8.md +++ b/docs/release-notes/rl-0.8.md @@ -15,6 +15,12 @@ - Add Haskell support under `vim.languages.haskell` using [haskell-tools.nvim]. +[horriblename](https://github.com/horriblename): + +[blink.cmp]: https://github.com/saghen/blink.cmp + +- Add [blink.cmp] support + [diniamo](https://github.com/diniamo): - Add Odin support under `vim.languages.odin`. From 90cb9b7293436193857ea5af58872dfd3907ddc2 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Thu, 26 Dec 2024 05:05:26 +0100 Subject: [PATCH 16/19] lspsignature: add assertion against blink.cmp --- modules/plugins/lsp/lsp-signature/config.nix | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/modules/plugins/lsp/lsp-signature/config.nix b/modules/plugins/lsp/lsp-signature/config.nix index c9940534..535b2534 100644 --- a/modules/plugins/lsp/lsp-signature/config.nix +++ b/modules/plugins/lsp/lsp-signature/config.nix @@ -10,6 +10,16 @@ cfg = config.vim.lsp; in { config = mkIf (cfg.enable && cfg.lspSignature.enable) { + assertions = [ + { + assertion = !config.vim.autocomplete.blink-cmp.enable; + message = '' + lsp-signature does not work with blink.cmp. Please use blink.cmp's builtin signature feature: + + vim.autocomplete.blink-cmp.setupOpts.signature.enabled = true; + ''; + } + ]; vim = { startPlugins = [ "lsp-signature" From fb91b1bbaa74532d80f150e5fc93c9ed9378d084 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Thu, 26 Dec 2024 05:23:19 +0100 Subject: [PATCH 17/19] blink: do not inherit vim's lsp capabilities --- modules/plugins/lsp/config.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/plugins/lsp/config.nix b/modules/plugins/lsp/config.nix index 550f7cc7..f91b379f 100644 --- a/modules/plugins/lsp/config.nix +++ b/modules/plugins/lsp/config.nix @@ -173,7 +173,7 @@ in { ''} ${optionalString usingBlinkCmp '' - capabilities = require('blink.cmp').get_lsp_capabilities(capabilities) + capabilities = require('blink.cmp').get_lsp_capabilities() ''} ''; }; From c2185f25df6ae4c908a507d68bb63885c2f84a14 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Thu, 26 Dec 2024 05:38:31 +0100 Subject: [PATCH 18/19] blink: disable cmdline completion --- modules/plugins/completion/blink-cmp/blink-cmp.nix | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/modules/plugins/completion/blink-cmp/blink-cmp.nix b/modules/plugins/completion/blink-cmp/blink-cmp.nix index 5a374940..d5839201 100644 --- a/modules/plugins/completion/blink-cmp/blink-cmp.nix +++ b/modules/plugins/completion/blink-cmp/blink-cmp.nix @@ -36,6 +36,12 @@ in { description = "Default list of sources to enable for completion."; }; + cmdline = mkOption { + type = listOf str; + default = []; + description = "List of sources to enable for cmdline"; + }; + providers = mkOption { type = attrsOf providerType; default = {}; From 9be26f2ac3376ed6b0b36d6a49bdc5ab0027ecae Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 29 Dec 2024 02:29:18 +0100 Subject: [PATCH 19/19] blink: allow null sources.cmdline --- modules/plugins/completion/blink-cmp/blink-cmp.nix | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/modules/plugins/completion/blink-cmp/blink-cmp.nix b/modules/plugins/completion/blink-cmp/blink-cmp.nix index d5839201..021441b2 100644 --- a/modules/plugins/completion/blink-cmp/blink-cmp.nix +++ b/modules/plugins/completion/blink-cmp/blink-cmp.nix @@ -1,6 +1,6 @@ {lib, ...}: let inherit (lib.options) mkEnableOption mkOption literalMD; - inherit (lib.types) listOf str either attrsOf submodule enum anything int; + inherit (lib.types) listOf str either attrsOf submodule enum anything int nullOr; inherit (lib.nvim.types) mkPluginSetupOption luaInline; inherit (lib.nvim.binds) mkMappingOption; inherit (lib.nvim.config) mkBool; @@ -37,9 +37,9 @@ in { }; cmdline = mkOption { - type = listOf str; + type = nullOr (listOf str); default = []; - description = "List of sources to enable for cmdline"; + description = "List of sources to enable for cmdline. Null means use default source list."; }; providers = mkOption {