From af0eed84e06784b6c86abe78be5ed454ac2a5ea0 Mon Sep 17 00:00:00 2001 From: diniamo Date: Wed, 1 Jan 2025 12:59:13 +0100 Subject: [PATCH] wrapper/build: improve noBuildPlug --- modules/wrapper/build/config.nix | 31 ++++++++++++++++++------------- 1 file changed, 18 insertions(+), 13 deletions(-) diff --git a/modules/wrapper/build/config.nix b/modules/wrapper/build/config.nix index 1faa2cc..ee5b4fd 100644 --- a/modules/wrapper/build/config.nix +++ b/modules/wrapper/build/config.nix @@ -9,30 +9,35 @@ inherit (pkgs) vimPlugins; inherit (lib.strings) isString; inherit (lib.lists) filter map; + inherit (builtins) path; # alias to the internal configuration vimOptions = config.vim; - noBuildPlug = {pname, ...} @ attrs: let - src = inputs."plugin-${attrs.pname}"; - in - { - version = src.shortRev or src.shortDirtyRev or "dirty"; - outPath = src; - passthru.vimPlugin = false; - } - // attrs; + noBuildPlug = pname: let + input = inputs."plugin-${pname}"; + version = input.shortRev or input.shortDirtyRev or "dirty"; + in { + # vim.lazy.plugins relies on pname, so we only set that here + # version isn't needed for anything, but inherit it anyway for correctness + inherit pname version; + outPath = path { + name = "${pname}-0-unstable-${version}"; + path = input.outPath; + }; + passthru.vimPlugin = false; + }; # build a vim plugin with the given name and arguments # if the plugin is nvim-treesitter, warn the user to use buildTreesitterPlug # instead buildPlug = attrs: let - src = inputs."plugin-${attrs.pname}"; + input = inputs."plugin-${attrs.pname}"; in pkgs.vimUtils.buildVimPlugin ( { - version = src.shortRev or src.shortDirtyRev or "dirty"; - inherit src; + version = input.shortRev or input.shortDirtyRev or "dirty"; + src = input.outPath; } // attrs ); @@ -51,7 +56,7 @@ map ( plug: if (isString plug) - then pluginBuilders.${plug} or (noBuildPlug {pname = plug;}) + then pluginBuilders.${plug} or (noBuildPlug plug) else plug ) (filter (f: f != null) plugins);