summary refs log tree commit diff
path: root/release.nix
diff options
context:
space:
mode:
authorLudovic Courtès <ludo@gnu.org>2013-05-12 15:18:17 +0200
committerLudovic Courtès <ludo@gnu.org>2013-05-12 15:18:17 +0200
commit9b1ef2f3232e7af111ba05353008ebd2f8955f02 (patch)
treebe43933556a93f0ec32e5cd43a890dfc626ba1cb /release.nix
parent46614bba7c164745d63ec9542f7ea7cd5cff26eb (diff)
downloadguix-9b1ef2f3232e7af111ba05353008ebd2f8955f02.tar.gz
release.nix: Revert back to before unchroot experiments.
* release.nix: Revert to commit 4050e5d6cfe8f7af29f10b2f1b3c7febdc10946a.
Diffstat (limited to 'release.nix')
-rw-r--r--release.nix70
1 files changed, 12 insertions, 58 deletions
diff --git a/release.nix b/release.nix
index 86560ea15a..369d54ed96 100644
--- a/release.nix
+++ b/release.nix
@@ -1,5 +1,5 @@
 /* GNU Guix --- Functional package management for GNU
-   Copyright (C) 2012, 2013  Ludovic Courtès <ludo@gnu.org>
+   Copyright (C) 2012  Ludovic Courtès <ludo@gnu.org>
 
    This file is part of GNU Guix.
 
@@ -26,39 +26,6 @@ let
   succeedOnFailure = true;
   keepBuildDirectory = true;
 
-  # Run the given derivation in outside of a chroot.  This hack is used on
-  # hydra.gnu.org where we want Guix derivations to run in a chroot that lacks
-  # /bin, whereas Nixpkgs relies on /bin/sh.
-  unchroot =
-    let
-      pkgs = import nixpkgs {};
-
-      # XXX: The `python' derivation contains a `modules' attribute that makes
-      # `overrideDerivation' fail with "cannot coerce an attribute set (except
-      # a derivation) to a string", so just remove it.
-      pythonKludge = drv: removeAttrs drv [ "modules" ];
-    in
-      drv:
-        if builtins.isAttrs drv
-        then pkgs.lib.overrideDerivation (pythonKludge drv) (args: {
-          __noChroot = true;
-          nativeBuildInputs = map unchroot args.nativeBuildInputs;
-          propagatedNativeBuildInputs =
-            map unchroot args.propagatedNativeBuildInputs;
-        })
-        else drv;
-
-  # Return a Nixpkgs with some derivations "unchrooted".
-  unchrootedNixpkgs = system:
-    import nixpkgs {
-      # XXX: Hack to make sure these ones also get "unchrooted".
-      config.packageOverrides = pkgs: {
-        zlib = unchroot pkgs.zlib;
-        libunistring = unchroot pkgs.libunistring;
-      };
-      inherit system;
-    };
-
   # The Guile used to bootstrap the whole thing.  It's normally
   # downloaded by the build system, but here we download it via a
   # fixed-output derivation and stuff it into the build tree.
@@ -77,39 +44,27 @@ let
 
   jobs = {
     tarball =
-      unchroot
-      (let pkgs = unchrootedNixpkgs builtins.currentSystem; in
+      let pkgs = import nixpkgs {}; in
       pkgs.releaseTools.sourceTarball {
         name = "guix-tarball";
         src = <guix>;
-        buildInputs =
-          let git_light = pkgs.git.override {
-              # Minimal Git to avoid building too many dependencies.
-              withManual = false;
-              pythonSupport = false;
-              svnSupport = false;
-              guiSupport = false;
-            };
-          in
-            [ git_light ] ++
-            (with pkgs; [ guile sqlite bzip2 libgcrypt ]);
-        nativeBuildInputs = with pkgs; [ texinfo gettext cvs pkgconfig ];
+        buildInputs = with pkgs; [ guile sqlite bzip2 git libgcrypt ];
+        buildNativeInputs = with pkgs; [ texinfo gettext cvs pkgconfig ];
         preAutoconf = ''git config submodule.nix.url "${<nix>}"'';
         configureFlags =
           [ "--with-libgcrypt-prefix=${pkgs.libgcrypt}"
             "--localstatedir=/nix/var"
           ];
-      });
+      };
 
     build =
       { system ? builtins.currentSystem }:
 
-      unchroot
-      (let pkgs = unchrootedNixpkgs system; in
+      let pkgs = import nixpkgs { inherit system; }; in
       pkgs.releaseTools.nixBuild {
         name = "guix";
         buildInputs = with pkgs; [ guile sqlite bzip2 libgcrypt ];
-        nativeBuildInputs = [ pkgs.pkgconfig ];
+        buildNativeInputs = [ pkgs.pkgconfig ];
         src = jobs.tarball;
         configureFlags =
           [ "--with-libgcrypt-prefix=${pkgs.libgcrypt}"
@@ -128,15 +83,14 @@ let
 
         inherit succeedOnFailure keepBuildDirectory
           buildOutOfSourceTree;
-      });
+      };
 
 
     build_disable_daemon =
       { system ? builtins.currentSystem }:
 
-      unchroot
-      (let
-        pkgs = unchrootedNixpkgs system;
+      let
+        pkgs = import nixpkgs { inherit system; };
         build = jobs.build { inherit system; };
       in
         pkgs.lib.overrideDerivation build ({ configureFlags, ... }: {
@@ -147,7 +101,7 @@ let
           # the chroot.
           preConfigure = "export NIX_REMOTE=daemon";
           __noChroot = true;
-        }));
+        });
 
     # Jobs to test the distro.
     distro = {
@@ -155,7 +109,7 @@ let
         { system ? builtins.currentSystem }:
 
         let
-          pkgs = unchrootedNixpkgs system;
+          pkgs = import nixpkgs { inherit system; };
           guix = jobs.build { inherit system; };
         in
           # XXX: We have no way to tell the Nix code to swallow the .drv