about summary refs log tree commit diff
diff options
context:
space:
mode:
authorLudovic Courtès <ludo@gnu.org>2010-05-19 21:26:36 +0000
committerLudovic Courtès <ludo@gnu.org>2010-05-19 21:26:36 +0000
commit0639ff01ea2c52ebed59766a6f83f209f6c99473 (patch)
tree13d4daae727bede7088f6c5b5e7e2b8579d65829
parentcc6ca8b2ae628b5623fab2057a209af24650448a (diff)
downloadnixlib-0639ff01ea2c52ebed59766a6f83f209f6c99473.tar
nixlib-0639ff01ea2c52ebed59766a6f83f209f6c99473.tar.gz
nixlib-0639ff01ea2c52ebed59766a6f83f209f6c99473.tar.bz2
nixlib-0639ff01ea2c52ebed59766a6f83f209f6c99473.tar.lz
nixlib-0639ff01ea2c52ebed59766a6f83f209f6c99473.tar.xz
nixlib-0639ff01ea2c52ebed59766a6f83f209f6c99473.tar.zst
nixlib-0639ff01ea2c52ebed59766a6f83f209f6c99473.zip
glibc: Fix non-Linux builds.
svn path=/nixpkgs/trunk/; revision=21890
-rw-r--r--pkgs/development/libraries/glibc-2.11/builder2.sh49
-rw-r--r--pkgs/development/libraries/glibc-2.11/default.nix7
2 files changed, 55 insertions, 1 deletions
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 { })
 
   //