mirror of
https://github.com/nix-community/home-manager
synced 2024-11-18 09:09:45 +01:00
be97e96dab
With this it is possible to build a specific test by running $ nix build -L .#test-{test name} For example $ nix build -L .#test-files-text
132 lines
4.2 KiB
Nix
132 lines
4.2 KiB
Nix
{
|
|
description = "Home Manager for Nix";
|
|
|
|
inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
|
|
|
outputs = { self, nixpkgs, ... }:
|
|
{
|
|
nixosModules = rec {
|
|
home-manager = import ./nixos;
|
|
default = home-manager;
|
|
};
|
|
# deprecated in Nix 2.8
|
|
nixosModule = self.nixosModules.default;
|
|
|
|
darwinModules = rec {
|
|
home-manager = import ./nix-darwin;
|
|
default = home-manager;
|
|
};
|
|
# unofficial; deprecated in Nix 2.8
|
|
darwinModule = self.darwinModules.default;
|
|
|
|
templates = {
|
|
standalone = {
|
|
path = ./templates/standalone;
|
|
description = "Standalone setup";
|
|
};
|
|
nixos = {
|
|
path = ./templates/nixos;
|
|
description = "Home Manager as a NixOS module,";
|
|
};
|
|
nix-darwin = {
|
|
path = ./templates/nix-darwin;
|
|
description = "Home Manager as a nix-darwin module,";
|
|
};
|
|
};
|
|
|
|
defaultTemplate = self.templates.standalone;
|
|
|
|
lib = {
|
|
hm = (import ./modules/lib/stdlib-extended.nix nixpkgs.lib).hm;
|
|
homeManagerConfiguration = { modules ? [ ], pkgs, lib ? pkgs.lib
|
|
, extraSpecialArgs ? { }, check ? true
|
|
# Deprecated:
|
|
, configuration ? null, extraModules ? null, stateVersion ? null
|
|
, username ? null, homeDirectory ? null, system ? null }@args:
|
|
let
|
|
msgForRemovedArg = ''
|
|
The 'homeManagerConfiguration' arguments
|
|
|
|
- 'configuration',
|
|
- 'username',
|
|
- 'homeDirectory'
|
|
- 'stateVersion',
|
|
- 'extraModules', and
|
|
- 'system'
|
|
|
|
have been removed. Instead use the arguments 'pkgs' and
|
|
'modules'. See the 22.11 release notes for more: https://nix-community.github.io/home-manager/release-notes.html#sec-release-22.11-highlights
|
|
'';
|
|
|
|
throwForRemovedArgs = v:
|
|
let
|
|
used = builtins.filter (n: (args.${n} or null) != null) [
|
|
"configuration"
|
|
"username"
|
|
"homeDirectory"
|
|
"stateVersion"
|
|
"extraModules"
|
|
"system"
|
|
];
|
|
msg = msgForRemovedArg + ''
|
|
|
|
|
|
Deprecated args passed: ''
|
|
+ builtins.concatStringsSep " " used;
|
|
in lib.throwIf (used != [ ]) msg v;
|
|
|
|
in throwForRemovedArgs (import ./modules {
|
|
inherit pkgs lib check extraSpecialArgs;
|
|
configuration = { ... }: {
|
|
imports = modules
|
|
++ [{ programs.home-manager.path = toString ./.; }];
|
|
nixpkgs = {
|
|
config = nixpkgs.lib.mkDefault pkgs.config;
|
|
inherit (pkgs) overlays;
|
|
};
|
|
};
|
|
});
|
|
};
|
|
} // (let
|
|
forAllSystems = nixpkgs.lib.genAttrs nixpkgs.lib.systems.flakeExposed;
|
|
in {
|
|
devShells = forAllSystems (system:
|
|
let
|
|
pkgs = nixpkgs.legacyPackages.${system};
|
|
tests = import ./tests { inherit pkgs; };
|
|
in tests.run);
|
|
|
|
formatter = forAllSystems (system:
|
|
let pkgs = nixpkgs.legacyPackages.${system};
|
|
in pkgs.linkFarm "format" [{
|
|
name = "bin/format";
|
|
path = ./format;
|
|
}]);
|
|
|
|
packages = forAllSystems (system:
|
|
let
|
|
pkgs = nixpkgs.legacyPackages.${system};
|
|
lib = pkgs.lib;
|
|
releaseInfo = nixpkgs.lib.importJSON ./release.json;
|
|
docs = import ./docs {
|
|
inherit pkgs;
|
|
inherit (releaseInfo) release isReleaseBranch;
|
|
};
|
|
hmPkg = pkgs.callPackage ./home-manager { path = toString ./.; };
|
|
|
|
testPackages = let
|
|
tests = import ./tests { inherit pkgs; };
|
|
renameTestPkg = n: lib.nameValuePair "test-${n}";
|
|
in lib.mapAttrs' renameTestPkg tests.build;
|
|
in {
|
|
default = hmPkg;
|
|
home-manager = hmPkg;
|
|
|
|
docs-html = docs.manual.html;
|
|
docs-json = docs.options.json;
|
|
docs-manpages = docs.manPages;
|
|
} // testPackages);
|
|
|
|
defaultPackage = forAllSystems (system: self.packages.${system}.default);
|
|
});
|
|
}
|