From 0639ff01ea2c52ebed59766a6f83f209f6c99473 Mon Sep 17 00:00:00 2001 From: Ludovic Courtès Date: Wed, 19 May 2010 21:26:36 +0000 Subject: glibc: Fix non-Linux builds. svn path=/nixpkgs/trunk/; revision=21890 --- pkgs/development/libraries/glibc-2.11/builder2.sh | 49 +++++++++++++++++++++++ pkgs/development/libraries/glibc-2.11/default.nix | 7 +++- 2 files changed, 55 insertions(+), 1 deletion(-) create mode 100644 pkgs/development/libraries/glibc-2.11/builder2.sh diff --git a/pkgs/development/libraries/glibc-2.11/builder2.sh b/pkgs/development/libraries/glibc-2.11/builder2.sh new file mode 100644 index 000000000000..f52573dbb080 --- /dev/null +++ b/pkgs/development/libraries/glibc-2.11/builder2.sh @@ -0,0 +1,49 @@ +### XXX: This file should replace `builder.sh' in the `stdenv-updates' +### branch! + +# Glibc cannot have itself in its RPATH. +export NIX_NO_SELF_RPATH=1 + +source $stdenv/setup + +postConfigure() { + # Hack: get rid of the `-static' flag set by the bootstrap stdenv. + # This has to be done *after* `configure' because it builds some + # test binaries. + export NIX_CFLAGS_LINK= + export NIX_LDFLAGS_BEFORE= + + export NIX_DONT_SET_RPATH=1 + unset CFLAGS +} + + +postInstall() { + if test -n "$installLocales"; then + make localedata/install-locales + fi + + test -f $out/etc/ld.so.cache && rm $out/etc/ld.so.cache + + # FIXME: Use `test -n $linuxHeaders' when `kernelHeaders' has been + # renamed. + if test -z "$hurdHeaders"; then + # Include the Linux kernel headers in Glibc, except the `scsi' + # subdirectory, which Glibc provides itself. + (cd $out/include && \ + ln -sv $(ls -d $kernelHeaders/include/* | grep -v 'scsi$') .) + fi + + # Fix for NIXOS-54 (ldd not working on x86_64). Make a symlink + # "lib64" to "lib". + if test -n "$is64bit"; then + ln -s lib $out/lib64 + fi + + # This file, that should not remain in the glibc derivation, + # may have not been created during the preInstall + rm -f $out/lib/libgcc_s.so.1 +} + + +genericBuild diff --git a/pkgs/development/libraries/glibc-2.11/default.nix b/pkgs/development/libraries/glibc-2.11/default.nix index 7c92a0fe41b4..9ba106e74d41 100644 --- a/pkgs/development/libraries/glibc-2.11/default.nix +++ b/pkgs/development/libraries/glibc-2.11/default.nix @@ -39,7 +39,12 @@ in // (if hurdHeaders != null - then { inherit machHeaders hurdHeaders mig fetchgit; } + then { + inherit machHeaders hurdHeaders mig fetchgit; + + # XXX: Remove this hack in `stdenv-updates'. + builder = ./builder2.sh; + } else { }) // -- cgit 1.4.1