From cf053a3f32fdf20a1237656de2c49fd2b09a2457 Mon Sep 17 00:00:00 2001 From: Jack O'Sullivan Date: Thu, 21 Jul 2022 11:47:27 +0100 Subject: [PATCH] home-manager/common: Use nixpkgs flake for `pkgs` in Nix registry --- home-manager/default.nix | 4 ++-- home-manager/modules/common.nix | 4 ++-- nixos/default.nix | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/home-manager/default.nix b/home-manager/default.nix index 63979e2..d06bcc1 100644 --- a/home-manager/default.nix +++ b/home-manager/default.nix @@ -1,4 +1,4 @@ -{ lib, hmFlakes, inputs, pkgs', config, ... }: +{ lib, hmFlakes, pkgsFlakes, inputs, pkgs', config, ... }: let inherit (builtins) head tail mapAttrs attrValues; inherit (lib) flatten optional optionalAttrs mkOption mkDefault mkOptionType mkIf; @@ -24,7 +24,7 @@ let # config merging behaviour (or lack thereof; similar to NixOS module), we explicitly pass empty config. # TODO: Check if this is fixed in future. pkgs = pkgs'.${config'.nixpkgs}.${config'.system} // { config = { }; }; - extraSpecialArgs = { inherit inputs; }; + extraSpecialArgs = { inherit inputs pkgsFlakes; pkgsFlake = pkgsFlakes.${config'.nixpkgs}; }; "${modArg}" = (attrValues cfg.modules) ++ [ { warnings = flatten [ diff --git a/home-manager/modules/common.nix b/home-manager/modules/common.nix index 355381f..c9971bb 100644 --- a/home-manager/modules/common.nix +++ b/home-manager/modules/common.nix @@ -1,4 +1,4 @@ -{ lib, pkgs, pkgs', inputs, config, ... }@args: +{ lib, pkgsFlake, pkgs, pkgs', inputs, config, ... }@args: let inherit (builtins) listToAttrs mapAttrs readFile; inherit (lib) @@ -223,7 +223,7 @@ in pkgs = { to = { type = "path"; - path = "${pkgs.path}"; + path = "${pkgsFlake}"; }; exact = true; }; diff --git a/nixos/default.nix b/nixos/default.nix index 88b9d9c..331fb8c 100644 --- a/nixos/default.nix +++ b/nixos/default.nix @@ -31,7 +31,7 @@ let lib = pkgs.lib; # Put the inputs in specialArgs to avoid infinite recursion when modules try to do imports - specialArgs = { inherit inputs allAssignments; inherit (cfg) systems; }; + specialArgs = { inherit inputs pkgsFlakes pkgsFlake allAssignments; inherit (cfg) systems; }; # `baseModules` informs the manual which modules to document baseModules =