parent
936e388171
commit
711bb9b56a
|
@ -5,6 +5,11 @@ FIXINC_DUMMY=$NIX_BUILD_TOP/dummy
|
||||||
mkdir $FIXINC_DUMMY
|
mkdir $FIXINC_DUMMY
|
||||||
|
|
||||||
|
|
||||||
|
# libstdc++ needs this; otherwise it will use /lib/cpp, which is a Bad
|
||||||
|
# Thing.
|
||||||
|
export CPP="gcc -E"
|
||||||
|
|
||||||
|
|
||||||
preConfigure() {
|
preConfigure() {
|
||||||
|
|
||||||
if test "$noSysDirs" = "1"; then
|
if test "$noSysDirs" = "1"; then
|
||||||
|
@ -49,18 +54,10 @@ postConfigure() {
|
||||||
extraFlags="-Wl,-s -B$glibc/lib -isystem $glibc/include \
|
extraFlags="-Wl,-s -B$glibc/lib -isystem $glibc/include \
|
||||||
-L$glibc/lib -Wl,-dynamic-linker -Wl,$glibc/lib/ld-linux.so.2"
|
-L$glibc/lib -Wl,-dynamic-linker -Wl,$glibc/lib/ld-linux.so.2"
|
||||||
|
|
||||||
# Oh, what a hack. I should be shot for this.
|
# Use *real* header files, otherwise a limits.h is generated
|
||||||
# In stage 1, we should link against the previous GCC, but
|
# that does not include Glibc's limits.h (notably missing
|
||||||
# not afterwards. Otherwise we retain a dependency.
|
# SSIZE_MAX, which breaks the build).
|
||||||
# However, ld-wrapper, which adds the linker flags for the
|
export FIXINC_DUMMY=$(cat $NIX_GCC/nix-support/orig-libc)/include
|
||||||
# previous GCC, is also used in stage 2/3. We can prevent
|
|
||||||
# it from adding them by NIX_GLIBC_FLAGS_SET, but then
|
|
||||||
# gcc-wrapper will also not add them, thereby causing
|
|
||||||
# stage 1 to fail. So we use a trick to only set the
|
|
||||||
# flags in gcc-wrapper.
|
|
||||||
hook=$(pwd)/ld-wrapper-hook
|
|
||||||
echo "NIX_GLIBC_FLAGS_SET=1" > $hook
|
|
||||||
export NIX_LD_WRAPPER_START_HOOK=$hook
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mf=Makefile
|
mf=Makefile
|
||||||
|
|
|
@ -4,6 +4,8 @@
|
||||||
|
|
||||||
assert langC;
|
assert langC;
|
||||||
|
|
||||||
|
# !!! impurity: finds /usr/bin/as, /usr/bin/ranlib.
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation {
|
||||||
name = "gcc-3.3.6";
|
name = "gcc-3.3.6";
|
||||||
builder = ./builder.sh;
|
builder = ./builder.sh;
|
||||||
|
|
Loading…
Reference in New Issue