From 4cbe791f22310a1d1970b1aabd430394409477fc Mon Sep 17 00:00:00 2001 From: punkfairie Date: Thu, 21 Nov 2024 21:01:11 -0800 Subject: [PATCH] feat: Package definition --- packages/lixyvim/default.nix | 65 ++++++++++++++++++++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 packages/lixyvim/default.nix diff --git a/packages/lixyvim/default.nix b/packages/lixyvim/default.nix new file mode 100644 index 0000000..21db8c2 --- /dev/null +++ b/packages/lixyvim/default.nix @@ -0,0 +1,65 @@ +{ lib +, pkgs +, inputs +, neovim-settings ? { } +, neovim-config ? { } +, ... +}: +let + raw-modules = lib.snowfall.fs.get-default-nix-files-recursive ( + lib.snowfall.fs.get-file "/modules/nixvim" + ); + + wrapped-modules = builtins.map + ( + raw-module: + args@{ ... }: + let + module = import raw-module; + result = + if builtins.isFunction module then + module + ( + args + // { + # NOTE: nixvim doesn't allow for these to be customized so we must work around the + # module system here... + inherit lib pkgs; + } + ) + else + module; + in + result // { _file = raw-module; } + ) + raw-modules; + + raw-neovim = pkgs.nixvim.makeNixvimWithModule { + inherit pkgs; + + module = { + imports = wrapped-modules; + + config = lib.mkMerge [ + { + _module.args = { + settings = neovim-settings; + lib = lib.mkForce lib; + }; + } + + neovim-config + ]; + }; + }; + + neovim = raw-neovim.overrideAttrs (attrs: { + meta = attrs.meta // { + # NOTE: The default platforms specified aren't actually all + # supported by nixvim. Instead, only support the ones that can build with + # the module system. + platforms = builtins.attrNames inputs.nixvim.legacyPackages; + }; + }); +in +neovim