diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index ea157436..1cce9834 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -19,6 +19,8 @@ /modules/misc/news.nix @rycee +/modules/misc/nixpkgs-disabled.nix @thiagokokada + /modules/misc/numlock.nix @evanjs /tests/modules/misc/numlock @evanjs diff --git a/modules/misc/nixpkgs-disabled.nix b/modules/misc/nixpkgs-disabled.nix new file mode 100644 index 00000000..ab0f35df --- /dev/null +++ b/modules/misc/nixpkgs-disabled.nix @@ -0,0 +1,73 @@ +{ config, lib, pkgs, ... }: + +with lib; + +let + + cfg = config.nixpkgs; + + # Copied from nixpkgs.nix. + isConfig = x: builtins.isAttrs x || builtins.isFunction x; + + # Copied from nixpkgs.nix. + optCall = f: x: if builtins.isFunction f then f x else f; + + # Copied from nixpkgs.nix. + mergeConfig = lhs_: rhs_: + let + lhs = optCall lhs_ { inherit pkgs; }; + rhs = optCall rhs_ { inherit pkgs; }; + in lhs // rhs // optionalAttrs (lhs ? packageOverrides) { + packageOverrides = pkgs: + optCall lhs.packageOverrides pkgs + // optCall (attrByPath [ "packageOverrides" ] ({ }) rhs) pkgs; + } // optionalAttrs (lhs ? perlPackageOverrides) { + perlPackageOverrides = pkgs: + optCall lhs.perlPackageOverrides pkgs + // optCall (attrByPath [ "perlPackageOverrides" ] ({ }) rhs) pkgs; + }; + + # Copied from nixpkgs.nix. + configType = mkOptionType { + name = "nixpkgs-config"; + description = "nixpkgs config"; + check = x: + let traceXIfNot = c: if c x then true else lib.traceSeqN 1 x false; + in traceXIfNot isConfig; + merge = args: fold (def: mergeConfig def.value) { }; + }; + + # Copied from nixpkgs.nix. + overlayType = mkOptionType { + name = "nixpkgs-overlay"; + description = "nixpkgs overlay"; + check = builtins.isFunction; + merge = lib.mergeOneOption; + }; + +in { + meta.maintainers = with maintainers; [ thiagokokada ]; + + options.nixpkgs = { + config = mkOption { + default = null; + type = types.nullOr configType; + visible = false; + }; + + overlays = mkOption { + default = null; + type = types.nullOr (types.listOf overlayType); + visible = false; + }; + }; + + config = { + assertions = [{ + assertion = cfg.config == null || cfg.overlays == null; + message = '' + `nixpkgs` options are disabled when `home-manager.useGlobalPkgs` is enabled. + ''; + }]; + }; +} diff --git a/modules/modules.nix b/modules/modules.nix index e7dc912c..337951ab 100644 --- a/modules/modules.nix +++ b/modules/modules.nix @@ -242,7 +242,8 @@ let ./xsession.nix (pkgs.path + "/nixos/modules/misc/assertions.nix") (pkgs.path + "/nixos/modules/misc/meta.nix") - ] ++ optional useNixpkgsModule ./misc/nixpkgs.nix; + ] ++ optional useNixpkgsModule ./misc/nixpkgs.nix + ++ optional (!useNixpkgsModule) ./misc/nixpkgs-disabled.nix; pkgsModule = { config, ... }: { config = {