nvim-cmp: fix snippet not being able to be null

This commit is contained in:
Pedro Alves 2022-08-05 15:01:10 +01:00
parent 5cb317a5cb
commit 70dd3446fb

View file

@ -7,9 +7,11 @@ let
cmpLib = import ./cmp-helpers.nix args; cmpLib = import ./cmp-helpers.nix args;
# functionName should be a string # functionName should be a string
# parameters should be a list of strings # parameters should be a list of strings
wrapWithFunction = functionName: parameters: let wrapWithFunction = functionName: parameters:
let
parameterString = strings.concatStringsSep "," parameters; parameterString = strings.concatStringsSep "," parameters;
in ''${functionName}(${parameterString})''; in
''${functionName}(${parameterString})'';
in in
{ {
options.programs.nixvim.plugins.nvim-cmp = { options.programs.nixvim.plugins.nvim-cmp = {
@ -17,7 +19,7 @@ in
performance = mkOption { performance = mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
debounce = mkOption { debounce = mkOption {
type = types.nullOr types.int; type = types.nullOr types.int;
@ -39,7 +41,7 @@ in
snippet = mkOption { snippet = mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
expand = mkOption { expand = mkOption {
type = types.nullOr types.str; type = types.nullOr types.str;
@ -57,20 +59,21 @@ in
}; };
mappingPresets = mkOption { mappingPresets = mkOption {
default = []; default = [ ];
type = types.listOf (types.enum [ type = types.listOf (types.enum [
"insert" "insert"
"cmdline" "cmdline"
# Not sure if there are more or if this should just be str # Not sure if there are more or if this should just be str
]); ]);
description = "Mapping presets to use; cmp.mapping.preset.\${mappingPreset} will be called with the configured mappings"; description = "Mapping presets to use; cmp.mapping.preset.\${mappingPreset} will be called with the configured mappings";
example = '' example = ''
[ "insert" "cmdline" ] [ "insert" "cmdline" ]
''; '';
}; };
mapping = mkOption { mapping = mkOption {
default = null; default = null;
type = types.nullOr (types.attrsOf (types.either types.str (types.submodule ({...}: { type = types.nullOr (types.attrsOf (types.either types.str (types.submodule ({ ... }: {
options = { options = {
action = mkOption { action = mkOption {
type = types.nonEmptyStr; type = types.nonEmptyStr;
@ -111,7 +114,7 @@ in
completion = mkOption { completion = mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
keyword_length = mkOption { keyword_length = mkOption {
default = null; default = null;
@ -140,7 +143,7 @@ in
confirmation = mkOption { confirmation = mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
get_commit_characters = mkOption { get_commit_characters = mkOption {
default = null; default = null;
@ -153,7 +156,7 @@ in
formatting = mkOption { formatting = mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
fields = mkOption { fields = mkOption {
default = null; default = null;
@ -171,7 +174,7 @@ in
matching = mkOption { matching = mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
disallow_fuzzy_matching = mkOption { disallow_fuzzy_matching = mkOption {
default = null; default = null;
@ -191,7 +194,7 @@ in
sorting = mkOption { sorting = mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
priority_weight = mkOption { priority_weight = mkOption {
default = null; default = null;
@ -212,8 +215,9 @@ in
''; '';
}; };
sources = let sources =
source_config = types.submodule ({...}: { let
source_config = types.submodule ({ ... }: {
options = { options = {
name = mkOption { name = mkOption {
type = types.str; type = types.str;
@ -258,7 +262,8 @@ in
}; };
}; };
}); });
in mkOption { in
mkOption {
default = null; default = null;
type = with types; nullOr (either (listOf source_config) (listOf (listOf source_config))); type = with types; nullOr (either (listOf source_config) (listOf (listOf source_config)));
description = '' description = ''
@ -278,7 +283,7 @@ in
view = mkOption { view = mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
entries = mkOption { entries = mkOption {
default = null; default = null;
@ -288,18 +293,20 @@ in
})); }));
}; };
window = let window =
let
# Reusable options # Reusable options
border = with types; mkNullOrOption (either str (listOf str)) null; border = with types; mkNullOrOption (either str (listOf str)) null;
winhighlight = mkNullOrOption types.str null; winhighlight = mkNullOrOption types.str null;
zindex = mkNullOrOption types.int null; zindex = mkNullOrOption types.int null;
in mkOption { in
mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
completion = mkOption { completion = mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
inherit border winhighlight zindex; inherit border winhighlight zindex;
}; };
@ -308,7 +315,7 @@ in
documentation = mkOption { documentation = mkOption {
default = null; default = null;
type = types.nullOr (types.submodule ({...}: { type = types.nullOr (types.submodule ({ ... }: {
options = { options = {
inherit border winhighlight zindex; inherit border winhighlight zindex;
max_width = mkNullOrOption types.int "Window's max width"; max_width = mkNullOrOption types.int "Window's max width";
@ -324,7 +331,8 @@ in
experimental = mkNullOrOption types.attrs "Experimental features"; experimental = mkNullOrOption types.attrs "Experimental features";
}; };
config = let config =
let
options = { options = {
enabled = cfg.enable; enabled = cfg.enable;
performance = cfg.performance; performance = cfg.performance;
@ -334,42 +342,56 @@ in
# If null then null # If null then null
# If an attribute is a string, just treat it as lua code for that mapping # If an attribute is a string, just treat it as lua code for that mapping
# If an attribute is a module, create a mapping with cmp.mapping() using the action as the first input and the modes as the second. # If an attribute is a module, create a mapping with cmp.mapping() using the action as the first input and the modes as the second.
mapping = let mapping =
mappings = if (isNull cfg.mapping) then null let
else mapAttrs (bind: mapping: helpers.mkRaw (if isString mapping then mapping mappings =
else "cmp.mapping(${mapping.action}${optionalString (mapping.modes != null && length mapping.modes >= 1) ("," + (helpers.toLuaObject mapping.modes))})")) cfg.mapping; if (isNull cfg.mapping) then null
else
mapAttrs
(bind: mapping: helpers.mkRaw (if isString mapping then mapping
else "cmp.mapping(${mapping.action}${optionalString (mapping.modes != null && length mapping.modes >= 1) ("," + (helpers.toLuaObject mapping.modes))})"))
cfg.mapping;
luaMappings = (helpers.toLuaObject mappings); luaMappings = (helpers.toLuaObject mappings);
wrapped = lists.fold (presetName: prevString: ''cmp.mapping.preset.${presetName}(${prevString})'') luaMappings cfg.mappingPresets; wrapped = lists.fold (presetName: prevString: ''cmp.mapping.preset.${presetName}(${prevString})'') luaMappings cfg.mappingPresets;
in helpers.mkRaw wrapped; in
helpers.mkRaw wrapped;
snippet = { snippet = {
expand = if (isNull cfg.snippet.expand) then null else helpers.mkRaw cfg.snippet.expand; expand = if (isNull cfg.snippet || isNull cfg.snippet.expand) then null else helpers.mkRaw cfg.snippet.expand;
}; };
completion = if (isNull cfg.completion) then null else { completion = if (isNull cfg.completion) then null else {
keyword_length = cfg.completion.keyword_length; keyword_length = cfg.completion.keyword_length;
keyword_pattern = cfg.completion.keyword_pattern; keyword_pattern = cfg.completion.keyword_pattern;
autocomplete = if (isNull cfg.completion.autocomplete) then null else mkRaw cfg.completion.autocomplete; autocomplete = if (isNull cfg.completion.autocomplete) then null else mkRaw cfg.completion.autocomplete;
completeopt = cfg.completion.completeopt; completeopt = cfg.completion.completeopt;
}; };
confirmation = if (isNull cfg.confirmation) then null else { confirmation = if (isNull cfg.confirmation) then null else {
get_commit_characters = get_commit_characters =
if (isString cfg.confirmation.get_commit_characters) then helpers.mkRaw cfg.confirmation.get_commit_characters if (isString cfg.confirmation.get_commit_characters) then helpers.mkRaw cfg.confirmation.get_commit_characters
else cfg.confirmation.get_commit_characters; else cfg.confirmation.get_commit_characters;
}; };
formatting = if (isNull cfg.formatting) then null else { formatting = if (isNull cfg.formatting) then null else {
fields = cfg.formatting.fields; fields = cfg.formatting.fields;
format = if (isNull cfg.formatting.format) then null else helpers.mkRaw cfg.formatting.format; format = if (isNull cfg.formatting.format) then null else helpers.mkRaw cfg.formatting.format;
}; };
matching = cfg.matching; matching = cfg.matching;
sorting = if (isNull cfg.sorting) then null else { sorting = if (isNull cfg.sorting) then null else {
priority_weight = cfg.sorting.priority_weight; priority_weight = cfg.sorting.priority_weight;
comparators = if (isNull cfg.sorting.comparators) then null else helpers.mkRaw cfg.sorting.comparators; comparators = if (isNull cfg.sorting.comparators) then null else helpers.mkRaw cfg.sorting.comparators;
}; };
sources = cfg.sources; sources = cfg.sources;
view = cfg.view; view = cfg.view;
window = cfg.window; window = cfg.window;
experimental = cfg.experimental; experimental = cfg.experimental;
}; };
in mkIf cfg.enable { in
mkIf cfg.enable {
programs.nixvim = { programs.nixvim = {
extraPlugins = [ pkgs.vimPlugins.nvim-cmp ]; extraPlugins = [ pkgs.vimPlugins.nvim-cmp ];
@ -380,18 +402,22 @@ in
# If auto_enable_sources is set to true, figure out which are provided by the user # If auto_enable_sources is set to true, figure out which are provided by the user
# and enable the corresponding plugins. # and enable the corresponding plugins.
plugins = let plugins =
flattened_sources = if (isNull cfg.sources) then [] else flatten cfg.sources; let
flattened_sources = if (isNull cfg.sources) then [ ] else flatten cfg.sources;
# Take only the names from the sources provided by the user # Take only the names from the sources provided by the user
found_sources = lists.unique (lists.map (source: source.name) flattened_sources); found_sources = lists.unique (lists.map (source: source.name) flattened_sources);
# A list of known source names # A list of known source names
known_source_names = attrNames cmpLib.pluginAndSourceNames; known_source_names = attrNames cmpLib.pluginAndSourceNames;
attrs_enabled = listToAttrs (map (name: { attrs_enabled = listToAttrs (map
(name: {
name = cmpLib.pluginAndSourceNames.${name}; name = cmpLib.pluginAndSourceNames.${name};
value.enable = mkIf (elem name found_sources) true; value.enable = mkIf (elem name found_sources) true;
}) known_source_names); })
in mkIf cfg.auto_enable_sources attrs_enabled; known_source_names);
in
mkIf cfg.auto_enable_sources attrs_enabled;
}; };
}; };
} }