From f46c31233225751eae2522247e6e7188c7a2f42b Mon Sep 17 00:00:00 2001 From: "Yang, Bo" Date: Thu, 12 Sep 2024 23:23:32 +0000 Subject: [PATCH 1/2] Set `key` for `modules` and `nixosModules` --- extras/modules.nix | 2 +- modules/nixosModules.nix | 6 +++++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/extras/modules.nix b/extras/modules.nix index 98e9a96..3626a15 100644 --- a/extras/modules.nix +++ b/extras/modules.nix @@ -14,10 +14,10 @@ let then module: module else module: - # TODO: set key? { _class = class; _file = "${toString moduleLocation}#modules.${escapeNixIdentifier class}.${escapeNixIdentifier moduleName}"; + key = "${toString moduleLocation}#modules.${escapeNixIdentifier class}.${escapeNixIdentifier moduleName}"; imports = [ module ]; }; in diff --git a/modules/nixosModules.nix b/modules/nixosModules.nix index 89cb301..1b1821d 100644 --- a/modules/nixosModules.nix +++ b/modules/nixosModules.nix @@ -15,7 +15,11 @@ in nixosModules = mkOption { type = types.lazyAttrsOf types.deferredModule; default = { }; - apply = mapAttrs (k: v: { _file = "${toString moduleLocation}#nixosModules.${k}"; imports = [ v ]; }); + apply = mapAttrs (k: v: { + _file = "${toString moduleLocation}#nixosModules.${k}"; + key = "${toString moduleLocation}#nixosModules.${k}"; + imports = [ v ]; + }); description = '' NixOS modules. From 95a0aa106dc33bfda2c01003782e243bafd2120d Mon Sep 17 00:00:00 2001 From: "Yang, Bo" Date: Tue, 8 Oct 2024 22:15:57 -0700 Subject: [PATCH 2/2] Add comments for `key` Co-authored-by: Robert Hensing --- modules/nixosModules.nix | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/modules/nixosModules.nix b/modules/nixosModules.nix index 1b1821d..126b507 100644 --- a/modules/nixosModules.nix +++ b/modules/nixosModules.nix @@ -17,6 +17,11 @@ in default = { }; apply = mapAttrs (k: v: { _file = "${toString moduleLocation}#nixosModules.${k}"; + # Note: this neglects to represent potential differences due to input + # overrides or flake-parts extendModules. However, the cost for this + # is too high or plain infeasible respectively. We choose to implement + # deduplication and disabledModules regardless, because not doing + # so poses a more direct problem. key = "${toString moduleLocation}#nixosModules.${k}"; imports = [ v ]; });