2005-11-29 02:40:33 +01:00
|
|
|
#! @shell@ -e
|
|
|
|
|
|
|
|
if test -n "$NIX_GCC_WRAPPER_START_HOOK"; then
|
2005-12-05 15:11:09 +01:00
|
|
|
source "$NIX_GCC_WRAPPER_START_HOOK"
|
2005-11-29 02:40:33 +01:00
|
|
|
fi
|
|
|
|
|
Big fixes in the cross build:
- Before this changes, cflags and ldflags for the native and the cross compiler
got mixed. Not all the gcc-wrapper/gcc-cross-wrapper variables are
independant now, but enough, I think.
- Fixed the generic stdenv expression, which did a big mess on buildInputs and
buildNativeInputs. Now it distinguishes when there is a stdenvCross or not.
Maybe we should have a single stdenv and forget about the stdenvCross
adapter - this could end in a stdenv a bit complex, but simpler than the
generic stdenv + adapter.
- Added basic support in pkgconfig for cross-builds: a single PKG_CONFIG_PATH
now works for both the cross and the native compilers, but I think this
should work well for most cases I can think of.
- I tried to fix the guile expression to cross-biuld; guile is built, but not
its manual, so the derivation still fails. Guile requires patching to
cross-build, as far as I understnad.
- Made the glibcCross build to be done through the usage of a
gcc-cross-wrapper over the gcc-cross-stage-static, instead of using it
directly.
- Trying to make physfs (a neverball dependency) cross build.
- Updated the gcc expression to support building a cross compiler without getting
derivation variables mixed with those of the stdenvCross.
svn path=/nixpkgs/branches/stdenv-updates/; revision=18534
2009-11-22 20:51:45 +01:00
|
|
|
if test -z "$NIX_CROSS_GLIBC_FLAGS_SET"; then
|
2005-12-05 15:11:09 +01:00
|
|
|
source @out@/nix-support/add-flags
|
2005-11-29 02:40:33 +01:00
|
|
|
fi
|
|
|
|
|
2005-12-05 15:11:09 +01:00
|
|
|
source @out@/nix-support/utils
|
2005-11-29 02:40:33 +01:00
|
|
|
|
|
|
|
|
|
|
|
# Figure out if linker flags should be passed. GCC prints annoying
|
|
|
|
# warnings when they are not needed.
|
|
|
|
dontLink=0
|
|
|
|
if test "$*" = "-v" -o -z "$*"; then
|
|
|
|
dontLink=1
|
|
|
|
else
|
|
|
|
for i in "$@"; do
|
|
|
|
if test "$i" = "-c"; then
|
|
|
|
dontLink=1
|
|
|
|
elif test "$i" = "-S"; then
|
|
|
|
dontLink=1
|
|
|
|
elif test "$i" = "-E"; then
|
|
|
|
dontLink=1
|
|
|
|
elif test "$i" = "-E"; then
|
|
|
|
dontLink=1
|
|
|
|
elif test "$i" = "-M"; then
|
|
|
|
dontLink=1
|
|
|
|
elif test "$i" = "-MM"; then
|
|
|
|
dontLink=1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
# Optionally filter out paths not refering to the store.
|
|
|
|
params=("$@")
|
|
|
|
if test "$NIX_ENFORCE_PURITY" = "1" -a -n "$NIX_STORE"; then
|
|
|
|
rest=()
|
|
|
|
n=0
|
|
|
|
while test $n -lt ${#params[*]}; do
|
|
|
|
p=${params[n]}
|
|
|
|
p2=${params[$((n+1))]}
|
|
|
|
if test "${p:0:3}" = "-L/" && badPath "${p:2}"; then
|
|
|
|
skip $p
|
|
|
|
elif test "$p" = "-L" && badPath "$p2"; then
|
|
|
|
n=$((n + 1)); skip $p2
|
|
|
|
elif test "${p:0:3}" = "-I/" && badPath "${p:2}"; then
|
|
|
|
skip $p
|
|
|
|
elif test "$p" = "-I" && badPath "$p2"; then
|
|
|
|
n=$((n + 1)); skip $p2
|
|
|
|
elif test "$p" = "-isystem" && badPath "$p2"; then
|
|
|
|
n=$((n + 1)); skip $p2
|
|
|
|
else
|
|
|
|
rest=("${rest[@]}" "$p")
|
|
|
|
fi
|
|
|
|
n=$((n + 1))
|
|
|
|
done
|
|
|
|
params=("${rest[@]}")
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
# Add the flags for the C compiler proper.
|
Big fixes in the cross build:
- Before this changes, cflags and ldflags for the native and the cross compiler
got mixed. Not all the gcc-wrapper/gcc-cross-wrapper variables are
independant now, but enough, I think.
- Fixed the generic stdenv expression, which did a big mess on buildInputs and
buildNativeInputs. Now it distinguishes when there is a stdenvCross or not.
Maybe we should have a single stdenv and forget about the stdenvCross
adapter - this could end in a stdenv a bit complex, but simpler than the
generic stdenv + adapter.
- Added basic support in pkgconfig for cross-builds: a single PKG_CONFIG_PATH
now works for both the cross and the native compilers, but I think this
should work well for most cases I can think of.
- I tried to fix the guile expression to cross-biuld; guile is built, but not
its manual, so the derivation still fails. Guile requires patching to
cross-build, as far as I understnad.
- Made the glibcCross build to be done through the usage of a
gcc-cross-wrapper over the gcc-cross-stage-static, instead of using it
directly.
- Trying to make physfs (a neverball dependency) cross build.
- Updated the gcc expression to support building a cross compiler without getting
derivation variables mixed with those of the stdenvCross.
svn path=/nixpkgs/branches/stdenv-updates/; revision=18534
2009-11-22 20:51:45 +01:00
|
|
|
extraAfter=($NIX_CROSS_CFLAGS_COMPILE)
|
2005-11-29 02:40:33 +01:00
|
|
|
extraBefore=()
|
|
|
|
|
|
|
|
if test "$dontLink" != "1"; then
|
|
|
|
|
|
|
|
# Add the flags that should only be passed to the compiler when
|
|
|
|
# linking.
|
Big fixes in the cross build:
- Before this changes, cflags and ldflags for the native and the cross compiler
got mixed. Not all the gcc-wrapper/gcc-cross-wrapper variables are
independant now, but enough, I think.
- Fixed the generic stdenv expression, which did a big mess on buildInputs and
buildNativeInputs. Now it distinguishes when there is a stdenvCross or not.
Maybe we should have a single stdenv and forget about the stdenvCross
adapter - this could end in a stdenv a bit complex, but simpler than the
generic stdenv + adapter.
- Added basic support in pkgconfig for cross-builds: a single PKG_CONFIG_PATH
now works for both the cross and the native compilers, but I think this
should work well for most cases I can think of.
- I tried to fix the guile expression to cross-biuld; guile is built, but not
its manual, so the derivation still fails. Guile requires patching to
cross-build, as far as I understnad.
- Made the glibcCross build to be done through the usage of a
gcc-cross-wrapper over the gcc-cross-stage-static, instead of using it
directly.
- Trying to make physfs (a neverball dependency) cross build.
- Updated the gcc expression to support building a cross compiler without getting
derivation variables mixed with those of the stdenvCross.
svn path=/nixpkgs/branches/stdenv-updates/; revision=18534
2009-11-22 20:51:45 +01:00
|
|
|
extraAfter=(${extraAfter[@]} $NIX_CROSS_CFLAGS_LINK)
|
2005-11-29 02:40:33 +01:00
|
|
|
|
|
|
|
# Add the flags that should be passed to the linker (and prevent
|
Big fixes in the cross build:
- Before this changes, cflags and ldflags for the native and the cross compiler
got mixed. Not all the gcc-wrapper/gcc-cross-wrapper variables are
independant now, but enough, I think.
- Fixed the generic stdenv expression, which did a big mess on buildInputs and
buildNativeInputs. Now it distinguishes when there is a stdenvCross or not.
Maybe we should have a single stdenv and forget about the stdenvCross
adapter - this could end in a stdenv a bit complex, but simpler than the
generic stdenv + adapter.
- Added basic support in pkgconfig for cross-builds: a single PKG_CONFIG_PATH
now works for both the cross and the native compilers, but I think this
should work well for most cases I can think of.
- I tried to fix the guile expression to cross-biuld; guile is built, but not
its manual, so the derivation still fails. Guile requires patching to
cross-build, as far as I understnad.
- Made the glibcCross build to be done through the usage of a
gcc-cross-wrapper over the gcc-cross-stage-static, instead of using it
directly.
- Trying to make physfs (a neverball dependency) cross build.
- Updated the gcc expression to support building a cross compiler without getting
derivation variables mixed with those of the stdenvCross.
svn path=/nixpkgs/branches/stdenv-updates/; revision=18534
2009-11-22 20:51:45 +01:00
|
|
|
# `ld-wrapper' from adding NIX_CROSS_LDFLAGS again).
|
|
|
|
for i in $NIX_CROSS_LDFLAGS_BEFORE; do
|
2010-08-09 23:37:31 +02:00
|
|
|
if test "${i:0:3}" = "-L/"; then
|
|
|
|
extraBefore=(${extraBefore[@]} "$i")
|
|
|
|
else
|
|
|
|
extraBefore=(${extraBefore[@]} "-Wl,$i")
|
|
|
|
fi
|
2005-11-29 02:40:33 +01:00
|
|
|
done
|
Big fixes in the cross build:
- Before this changes, cflags and ldflags for the native and the cross compiler
got mixed. Not all the gcc-wrapper/gcc-cross-wrapper variables are
independant now, but enough, I think.
- Fixed the generic stdenv expression, which did a big mess on buildInputs and
buildNativeInputs. Now it distinguishes when there is a stdenvCross or not.
Maybe we should have a single stdenv and forget about the stdenvCross
adapter - this could end in a stdenv a bit complex, but simpler than the
generic stdenv + adapter.
- Added basic support in pkgconfig for cross-builds: a single PKG_CONFIG_PATH
now works for both the cross and the native compilers, but I think this
should work well for most cases I can think of.
- I tried to fix the guile expression to cross-biuld; guile is built, but not
its manual, so the derivation still fails. Guile requires patching to
cross-build, as far as I understnad.
- Made the glibcCross build to be done through the usage of a
gcc-cross-wrapper over the gcc-cross-stage-static, instead of using it
directly.
- Trying to make physfs (a neverball dependency) cross build.
- Updated the gcc expression to support building a cross compiler without getting
derivation variables mixed with those of the stdenvCross.
svn path=/nixpkgs/branches/stdenv-updates/; revision=18534
2009-11-22 20:51:45 +01:00
|
|
|
for i in $NIX_CROSS_LDFLAGS; do
|
2010-08-09 23:37:31 +02:00
|
|
|
if test "${i:0:3}" = "-L/"; then
|
|
|
|
extraAfter=(${extraAfter[@]} "$i")
|
|
|
|
else
|
|
|
|
extraAfter=(${extraAfter[@]} "-Wl,$i")
|
|
|
|
fi
|
2005-11-29 02:40:33 +01:00
|
|
|
done
|
Big fixes in the cross build:
- Before this changes, cflags and ldflags for the native and the cross compiler
got mixed. Not all the gcc-wrapper/gcc-cross-wrapper variables are
independant now, but enough, I think.
- Fixed the generic stdenv expression, which did a big mess on buildInputs and
buildNativeInputs. Now it distinguishes when there is a stdenvCross or not.
Maybe we should have a single stdenv and forget about the stdenvCross
adapter - this could end in a stdenv a bit complex, but simpler than the
generic stdenv + adapter.
- Added basic support in pkgconfig for cross-builds: a single PKG_CONFIG_PATH
now works for both the cross and the native compilers, but I think this
should work well for most cases I can think of.
- I tried to fix the guile expression to cross-biuld; guile is built, but not
its manual, so the derivation still fails. Guile requires patching to
cross-build, as far as I understnad.
- Made the glibcCross build to be done through the usage of a
gcc-cross-wrapper over the gcc-cross-stage-static, instead of using it
directly.
- Trying to make physfs (a neverball dependency) cross build.
- Updated the gcc expression to support building a cross compiler without getting
derivation variables mixed with those of the stdenvCross.
svn path=/nixpkgs/branches/stdenv-updates/; revision=18534
2009-11-22 20:51:45 +01:00
|
|
|
export NIX_CROSS_LDFLAGS_SET=1
|
2005-11-29 02:40:33 +01:00
|
|
|
|
|
|
|
if test "$NIX_STRIP_DEBUG" = "1"; then
|
|
|
|
# Add executable-stripping flags.
|
|
|
|
extraAfter=(${extraAfter[@]} $NIX_CFLAGS_STRIP)
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Optionally print debug info.
|
|
|
|
if test "$NIX_DEBUG" = "1"; then
|
|
|
|
echo "original flags to @gccProg@:" >&2
|
|
|
|
for i in "${params[@]}"; do
|
|
|
|
echo " $i" >&2
|
|
|
|
done
|
|
|
|
echo "extraBefore flags to @gccProg@:" >&2
|
|
|
|
for i in ${extraBefore[@]}; do
|
|
|
|
echo " $i" >&2
|
|
|
|
done
|
|
|
|
echo "extraAfter flags to @gccProg@:" >&2
|
|
|
|
for i in ${extraAfter[@]}; do
|
|
|
|
echo " $i" >&2
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test -n "$NIX_GCC_WRAPPER_EXEC_HOOK"; then
|
2005-12-05 15:11:09 +01:00
|
|
|
source "$NIX_GCC_WRAPPER_EXEC_HOOK"
|
2005-11-29 02:40:33 +01:00
|
|
|
fi
|
|
|
|
|
2009-11-21 03:42:52 +01:00
|
|
|
# We want gcc to call the wrapper linker, not that of binutils.
|
|
|
|
export PATH="@ldPath@:$PATH"
|
2005-11-29 02:40:33 +01:00
|
|
|
|
|
|
|
# Call the real `gcc'. Filter out warnings from stderr about unused
|
|
|
|
# `-B' flags, since they confuse some programs. Deep bash magic to
|
|
|
|
# apply grep to stderr (by swapping stdin/stderr twice).
|
|
|
|
if test -z "$NIX_GCC_NEEDS_GREP"; then
|
|
|
|
@gccProg@ ${extraBefore[@]} "${params[@]}" ${extraAfter[@]}
|
|
|
|
else
|
|
|
|
(@gccProg@ ${extraBefore[@]} "${params[@]}" ${extraAfter[@]} 3>&2 2>&1 1>&3- \
|
|
|
|
| (grep -v 'file path prefix' || true); exit ${PIPESTATUS[0]}) 3>&2 2>&1 1>&3-
|
|
|
|
exit $?
|
|
|
|
fi
|