about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--release.nix33
1 files changed, 20 insertions, 13 deletions
diff --git a/release.nix b/release.nix
index 5e40ea59..288dfd76 100644
--- a/release.nix
+++ b/release.nix
@@ -1,15 +1,24 @@
-{ vuizvui ? { outPath  = ./.;
-              revCount = 12345;
-              shortRev = "abcdefg";
-            }
-, nixpkgs ? { outPath  = import ./nixpkgs-path.nix;
-              revCount = 12345;
-              shortRev = "abcdefg";
-            }
+{ vuizvui ? { outPath  = ./.; revCount = 12345; shortRev = "abcdefg"; }
+, nixpkgsSrc ? null
 , supportedSystems ? [ "i686-linux" "x86_64-linux" ]
 }:
 
 let
+  nixpkgsRevCount = nixpkgsSrc.revCount or 12345;
+  nixpkgsShortRev = nixpkgsSrc.shortRev or "abcdefg";
+
+  nixpkgs = let
+    patchedNixpkgs = (import nixpkgsSrc {}).stdenv.mkDerivation {
+      src = nixpkgsSrc;
+      phases = [ "unpackPhase" "installPhase" ];
+      installPhase = ''
+        sed -i -re 's!<nixpkgs([^>]*)>!<vuizvui/nixpkgs\1>!g' \
+          nixos/modules/installer/tools/nixos-rebuild.sh
+        cp -r . "$out"
+      '';
+    };
+  in if nixpkgsSrc == null then <nixpkgs> else patchedNixpkgs;
+
   system = "x86_64-linux";
   pkgsUpstream = import nixpkgs { inherit system; };
   root = import ./default.nix { inherit system; };
@@ -35,15 +44,13 @@ in with pkgsUpstream.lib; with builtins; {
     mkChannel = attrs: root.pkgs.mkChannel (rec {
       name = "vuizvui-channel-${attrs.name or "generic"}-${version}";
       version = "${toString vuizvui.revCount}.${vuizvui.shortRev}";
-      pkgsVer = "pre${toString nixpkgs.revCount}.${nixpkgs.shortRev}-vuizvui";
+      pkgsVer = "pre${toString nixpkgsRevCount}.${nixpkgsShortRev}-vuizvui";
       src = vuizvui;
       patchPhase = ''
         cp -r --no-preserve=mode,ownership "${nixpkgs}/" nixpkgs
-        find \( -iname '*.nix' -type f \
-             -o -path ./nixpkgs/nixos/modules/installer/tools/nixos-rebuild.sh \
-             \) -exec sed -i -re 's!<nixpkgs([^>]*)>!<vuizvui/nixpkgs\1>!g' {} +
         echo -n "$pkgsVer" > nixpkgs/.version-suffix
-        echo -n ${nixpkgs.rev or nixpkgs.shortRev} > nixpkgs/.git-revision
+        echo -n ${nixpkgs.rev or nixpkgsShortRev} > nixpkgs/.git-revision
+        echo './nixpkgs' > nixpkgs-path.nix
         touch .update-on-nixos-rebuild
       '';
     } // removeAttrs attrs [ "name" ]);