diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 866fd9920..05eecbe3e 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -13,9 +13,9 @@ jobs: steps: - uses: actions/checkout@v3 - name: Install nix corresponding to latest stable channel - uses: cachix/install-nix-action@v22 + uses: cachix/install-nix-action@v23 with: - install_url: https://github.com/nix-community/nix-unstable-installer/releases/download/nix-2.10.0pre20220822_7c3ab57/install + install_url: https://releases.nixos.org/nix/nix-2.13.6/install - run: nix-build ./release.nix -I nixpkgs=channel:${{ env.CURRENT_STABLE_CHANNEL }} -I darwin=. -A tests - run: nix-build ./release.nix -I nixpkgs=channel:${{ env.CURRENT_STABLE_CHANNEL }} -I darwin=. -A manpages - run: nix-build ./release.nix -I nixpkgs=channel:${{ env.CURRENT_STABLE_CHANNEL }} -I darwin=. -A examples.simple @@ -26,7 +26,7 @@ jobs: steps: - uses: actions/checkout@v3 - name: Install nix from current unstable channel - uses: cachix/install-nix-action@v22 + uses: cachix/install-nix-action@v23 - run: nix-build ./release.nix -I nixpkgs=channel:nixpkgs-unstable -I darwin=. -A tests - run: nix-build ./release.nix -I nixpkgs=channel:nixpkgs-unstable -I darwin=. -A manpages - run: nix-build ./release.nix -I nixpkgs=channel:nixpkgs-unstable -I darwin=. -A examples.simple @@ -37,9 +37,9 @@ jobs: steps: - uses: actions/checkout@v3 - name: Install nix corresponding to latest stable channel - uses: cachix/install-nix-action@v22 + uses: cachix/install-nix-action@v23 with: - install_url: https://github.com/nix-community/nix-unstable-installer/releases/download/nix-2.10.0pre20220822_7c3ab57/install + install_url: https://releases.nixos.org/nix/nix-2.13.6/install nix_path: nixpkgs=channel:${{ env.CURRENT_STABLE_CHANNEL }} - name: Install ${{ env.CURRENT_STABLE_CHANNEL }} channel run: | @@ -82,7 +82,7 @@ jobs: steps: - uses: actions/checkout@v3 - name: Install nix from current unstable channel - uses: cachix/install-nix-action@v22 + uses: cachix/install-nix-action@v23 with: nix_path: nixpkgs=channel:nixpkgs-unstable - name: Install nixpkgs-unstable channel @@ -126,9 +126,9 @@ jobs: steps: - uses: actions/checkout@v3 - name: Install nix version corresponding to latest stable channel - uses: cachix/install-nix-action@v22 + uses: cachix/install-nix-action@v23 with: - install_url: https://github.com/nix-community/nix-unstable-installer/releases/download/nix-2.10.0pre20220822_7c3ab57/install + install_url: https://releases.nixos.org/nix/nix-2.13.6/install - name: Install nix-darwin run: | mkdir -p ~/.config/nix-darwin @@ -209,7 +209,7 @@ jobs: steps: - uses: actions/checkout@v3 - name: Install nix from current unstable channel - uses: cachix/install-nix-action@v22 + uses: cachix/install-nix-action@v23 - name: Install nix-darwin run: | mkdir -p ~/.config/nix-darwin diff --git a/default.nix b/default.nix index 7c7e06b2b..c93b47833 100644 --- a/default.nix +++ b/default.nix @@ -16,7 +16,7 @@ let }; }; - # The source code of this repo needed by the [un]installers. + # The source code of this repo needed by the installer. nix-darwin = lib.cleanSource ( lib.cleanSourceWith { # We explicitly specify a name here otherwise `cleanSource` will use the @@ -30,5 +30,5 @@ in eval // { installer = pkgs.callPackage ./pkgs/darwin-installer { inherit nix-darwin; }; - uninstaller = pkgs.callPackage ./pkgs/darwin-uninstaller { inherit nix-darwin; }; + uninstaller = pkgs.callPackage ./pkgs/darwin-uninstaller { }; } diff --git a/flake.nix b/flake.nix index d09f4d6c5..e25fe6a6f 100644 --- a/flake.nix +++ b/flake.nix @@ -42,7 +42,7 @@ overlays.default = final: prev: { inherit (prev.callPackage ./pkgs/nix-tools { }) darwin-rebuild darwin-option darwin-version; - darwin-uninstaller = prev.callPackage ./pkgs/darwin-uninstaller { nix-darwin = self; }; + darwin-uninstaller = prev.callPackage ./pkgs/darwin-uninstaller { }; }; darwinModules.hydra = ./modules/examples/hydra.nix; diff --git a/modules/nix/nix-darwin.nix b/modules/nix/nix-darwin.nix index 7f07b458b..ad1ab8fbc 100644 --- a/modules/nix/nix-darwin.nix +++ b/modules/nix/nix-darwin.nix @@ -1,4 +1,4 @@ -{ config, pkgs, ... }: +{ config, pkgs, lib, ... }: let nix-tools = pkgs.callPackage ../../pkgs/nix-tools { @@ -7,22 +7,30 @@ let nixPackage = config.nix.package; }; + darwin-uninstaller = pkgs.callPackage ../../pkgs/darwin-uninstaller { }; + inherit (nix-tools) darwin-option darwin-rebuild darwin-version; in { - config = { + options = { + system.includeUninstaller = lib.mkOption { + type = lib.types.bool; + internal = true; + default = true; + }; + }; + config = { environment.systemPackages = [ # Include nix-tools by default darwin-option darwin-rebuild darwin-version - ]; + ] ++ lib.optional config.system.includeUninstaller darwin-uninstaller; system.build = { inherit darwin-option darwin-rebuild darwin-version; }; - }; } diff --git a/pkgs/darwin-uninstaller/configuration.nix b/pkgs/darwin-uninstaller/configuration.nix index 96a2165a2..6487774be 100644 --- a/pkgs/darwin-uninstaller/configuration.nix +++ b/pkgs/darwin-uninstaller/configuration.nix @@ -1,4 +1,4 @@ -{ config, lib, pkgs, ... }: +{ lib, ... }: with lib; diff --git a/pkgs/darwin-uninstaller/default.nix b/pkgs/darwin-uninstaller/default.nix index ca7be4891..94c07494a 100644 --- a/pkgs/darwin-uninstaller/default.nix +++ b/pkgs/darwin-uninstaller/default.nix @@ -1,18 +1,17 @@ -{ stdenv, nix, pkgs, nix-darwin }: +{ stdenv, lib, pkgs }: let - configuration = builtins.path { - name = "nix-darwin-uninstaller-configuration"; - path = ./.; - filter = name: _type: name != toString ./default.nix; + uninstallSystem = import ../../eval-config.nix { + inherit lib; + modules = [ + ./configuration.nix + { + nixpkgs.source = pkgs.path; + nixpkgs.hostPlatform = pkgs.system; + system.includeUninstaller = false; + } + ]; }; - - nixPath = pkgs.lib.concatStringsSep ":" [ - "darwin-config=${configuration}/configuration.nix" - "darwin=${nix-darwin}" - "nixpkgs=${pkgs.path}" - "$NIX_PATH" - ]; in stdenv.mkDerivation { @@ -62,10 +61,7 @@ stdenv.mkDerivation { esac fi - export nix=${nix} - export NIX_PATH=${nixPath} - system=$($nix/bin/nix-build '' -A system) - $system/sw/bin/darwin-rebuild switch + ${uninstallSystem.system}/sw/bin/darwin-rebuild activate if test -L /run/current-system; then sudo rm /run/current-system