* On Linux, build coreutils with ACL support.

svn path=/nixpkgs/branches/stdenv-updates/; revision=11848
This commit is contained in:
Eelco Dolstra 2008-05-19 15:12:03 +00:00
parent 79ed6fcf36
commit 1d6f0ab989
3 changed files with 29 additions and 15 deletions

View File

@ -4,7 +4,8 @@
# compiler and linker that do not search in default locations,
# ensuring purity of components produced by it.
{system, allPackages}:
# The function defaults are for easy testing.
{system ? "i686-linux", allPackages ? import ../../top-level/all-packages.nix}:
rec {
@ -98,7 +99,7 @@ rec {
# This function builds the various standard environments used during
# the bootstrap.
stdenvBootFun =
{gcc, staticGlibc, extraAttrs ? {}}:
{gcc, staticGlibc, extraAttrs ? {}, extraPath ? []}:
import ../generic {
name = "stdenv-linux-boot";
@ -106,9 +107,7 @@ rec {
preHook = ./scripts/prehook.sh;
stdenv = stdenvInitial;
shell = bootstrapTools.bash;
initialPath = [
staticTools
];
initialPath = [staticTools] ++ extraPath;
inherit gcc extraAttrs;
};
@ -154,6 +153,14 @@ rec {
};
# Ugh, some packages in stdenvLinuxBoot3Pkgs need "sh", so create a
# package that contains just a symlink to bash.
shSymlink = stdenvLinuxBoot2Pkgs.runCommand "sh-symlink" {} ''
ensureDir $out/bin
ln -s $shell $out/bin/sh
'';
# 6) Construct a third stdenv identical to the second, except that
# this one uses the dynamically linked GCC and Binutils from step
# 5. The other tools (e.g. coreutils) are still static.
@ -165,6 +172,7 @@ rec {
gcc = stdenvLinuxBoot2Pkgs.gcc.gcc;
};
extraAttrs = {inherit curl;};
extraPath = [stdenvLinuxBoot2Pkgs.replace shSymlink];
};
@ -178,7 +186,7 @@ rec {
# 8) Construct the final stdenv. It uses the Glibc, GCC and
# Binutils built above, and adds in dynamically linked versions
# of all other tools.
stdenvLinux = (import ../generic) {
stdenvLinux = import ../generic {
name = "stdenv-linux";
preHook = ./scripts/prehook.sh;
initialPath = [
@ -202,7 +210,8 @@ rec {
inherit (stdenvLinuxBoot2Pkgs) binutils /* gcc */ glibc;
inherit (stdenvLinuxBoot3Pkgs)
gzip bzip2 bash coreutils diffutils findutils gawk
gnumake gnused gnutar gnugrep patch patchelf;
gnumake gnused gnutar gnugrep patch patchelf
attr acl;
};
};

View File

@ -1,4 +1,4 @@
{stdenv, fetchurl}:
{stdenv, fetchurl, aclSupport ? false, acl}:
stdenv.mkDerivation {
name = "coreutils-6.11";
@ -12,4 +12,6 @@ stdenv.mkDerivation {
homepage = http://www.gnu.org/software/coreutils/;
description = "The basic file, shell and text manipulation utilities of the GNU operating system";
};
buildInputs = stdenv.lib.optional aclSupport acl;
}

View File

@ -440,7 +440,8 @@ rec {
then import ../tools/misc/coreutils-5
else import ../tools/misc/coreutils)
{
inherit fetchurl stdenv;
inherit fetchurl stdenv acl;
aclSupport = stdenv.isLinux;
});
cpio = import ../tools/archivers/cpio {
@ -2114,9 +2115,10 @@ rec {
inherit fetchurl stdenv ncurses;
};
acl = import ../development/libraries/acl {
inherit stdenv fetchurl gettext attr libtool;
};
acl = useFromStdenv "acl"
(import ../development/libraries/acl {
inherit stdenv fetchurl gettext attr libtool;
});
/*
agg = import ../development/libraries/agg {
@ -2165,9 +2167,10 @@ rec {
inherit fetchurl stdenv;
};
attr = import ../development/libraries/attr {
inherit stdenv fetchurl libtool gettext;
};
attr = useFromStdenv "acl"
(import ../development/libraries/attr {
inherit stdenv fetchurl libtool gettext;
});
audiofile = import ../development/libraries/audiofile {
inherit fetchurl stdenv;