diff options
Diffstat (limited to '')
-rw-r--r-- | flake/packages/default.nix | 44 | ||||
-rw-r--r-- | flake/packages/merge.nix | 86 |
2 files changed, 130 insertions, 0 deletions
diff --git a/flake/packages/default.nix b/flake/packages/default.nix index 4ab68775..708852a0 100644 --- a/flake/packages/default.nix +++ b/flake/packages/default.nix @@ -1,12 +1,54 @@ { + self, nixos-generators, defaultSpecialArgs, defaultModules, pkgs, sysLib, + nixVim, + system, ... }: let + inherit (pkgs) lib; + inherit (import ./merge.nix {inherit lib;}) merge; output = import ../../bootstrap {inherit pkgs sysLib;}; + args = { + inherit pkgs; + inherit (pkgs) lib; + }; + nvim = + builtins.mapAttrs ( + name: value: let + nvim_config = + import ../../home-manager/soispha/config/neovim/nixvim/default.nix + args; + build_args = args // {nixosConfig = value.config;}; + + merge_attrs = list_of_attrs: builtins.foldl' (x: y: merge [x y]) {} list_of_attrs; + resolve_imports = attrs: + merge_attrs (builtins.map (v: import v build_args) + attrs.imports); + + resolve_imports' = attrs: + if builtins.any (n: n == "imports") (builtins.attrNames attrs) + then + resolve_imports' (merge_attrs [ + (resolve_imports attrs) + (builtins.removeAttrs + attrs + ["imports"]) + ]) + else attrs; + + complete_config = resolve_imports' nvim_config; + in + nixVim.legacyPackages."${system}".makeNixvim + ( + builtins.removeAttrs + complete_config.programs.nixvim ["enable"] + ) + ) + self.nixosConfigurations; in { install-iso = nixos-generators.nixosGenerate { @@ -27,5 +69,7 @@ in ++ defaultModules; format = "iso"; }; + vim = nvim.tiamat; + inherit nvim; } // output diff --git a/flake/packages/merge.nix b/flake/packages/merge.nix new file mode 100644 index 00000000..8c8ed134 --- /dev/null +++ b/flake/packages/merge.nix @@ -0,0 +1,86 @@ +{lib, ...}: let + merge = merge_list: let + head_of_merge = builtins.head merge_list; + in + if builtins.isAttrs head_of_merge + then + builtins.zipAttrsWith ( + name: values: let + head_value = builtins.head values; + in + if builtins.isString head_value + then builtins.concatStringsSep "" values + else if builtins.isList head_value + then builtins.concatLists values + else if builtins.isAttrs head_value + then merge values + else builtins.head values + ) + merge_list + else if builtins.isString head_of_merge + then builtins.concatStringsSep "" merge_list + else if builtins.isList head_of_merge + then builtins.concatLists merge_list + else builtins.head merge_list; + + # Tests + ## Strings + a = { + a = '' + This is some + ''; + }; + b = { + a = '' + example text + ''; + }; + c = { + a = "(which is nice)"; + }; + ## Lists + d = { + a = ["element1" "element2"]; + }; + e = { + a = [["elment3" "elemnt4"]]; + }; + f = { + a = ["elemnt5"]; + }; + ## Pure strings + g = "This"; + h = "is"; + i = "some example text"; + j = '' + (with a newline) + ''; + ## Pure lists + k = ["element1"]; + l = ["element2" "element3"]; + m = ["element4"]; + + ## Prepared tests + tests = { + tests = []; # Uncomment to actually run the tests + test_strings = { + expr = merge [a b c]; + expected = {a = "This is some\nexample text\n(which is nice)";}; + }; + test_lists = { + expr = merge [d e f]; + expected = {a = ["element1" "element2" ["elment3" "elemnt4"] "elemnt5"];}; + }; + test_pure_strings = { + expr = merge [g h i j]; + expected = "Thisissome example text(with a newline)\n"; + }; + test_pure_lists = { + expr = merge [k l m]; + expected = ["element1" "element2" "element3" "element4"]; + }; + }; +in { + inherit merge; + result = lib.debug.runTests tests; +} |