diff options
author | Lluís Batlle i Rossell <viric@vicerveza.homeunix.net> | 2009-11-22 19:51:45 +0000 |
---|---|---|
committer | Lluís Batlle i Rossell <viric@vicerveza.homeunix.net> | 2009-11-22 19:51:45 +0000 |
commit | 585ba8c27f766a15abcab22c232170f6ae1cc0a9 (patch) | |
tree | 6b2411a130c9683b6696a63da584e56137029caf /pkgs/stdenv/generic | |
parent | 9dcff09187d5e41ed9bf4d841243a4bf6082c719 (diff) | |
download | nixlib-585ba8c27f766a15abcab22c232170f6ae1cc0a9.tar nixlib-585ba8c27f766a15abcab22c232170f6ae1cc0a9.tar.gz nixlib-585ba8c27f766a15abcab22c232170f6ae1cc0a9.tar.bz2 nixlib-585ba8c27f766a15abcab22c232170f6ae1cc0a9.tar.lz nixlib-585ba8c27f766a15abcab22c232170f6ae1cc0a9.tar.xz nixlib-585ba8c27f766a15abcab22c232170f6ae1cc0a9.tar.zst nixlib-585ba8c27f766a15abcab22c232170f6ae1cc0a9.zip |
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
Diffstat (limited to 'pkgs/stdenv/generic')
-rw-r--r-- | pkgs/stdenv/generic/default.nix | 14 | ||||
-rw-r--r-- | pkgs/stdenv/generic/setup.sh | 9 |
2 files changed, 17 insertions, 6 deletions
diff --git a/pkgs/stdenv/generic/default.nix b/pkgs/stdenv/generic/default.nix index 0755ee46904b..0ae71d183dec 100644 --- a/pkgs/stdenv/generic/default.nix +++ b/pkgs/stdenv/generic/default.nix @@ -55,6 +55,8 @@ let propagatedBuildNativeInputs = if attrs ? propagatedBuildNativeInputs then attrs.propagatedBuildNativeInputs else []; + crossConfig = if (attrs ? crossConfig) then attrs.crossConfig else + null; in { builder = if attrs ? realBuilder then attrs.realBuilder else shell; @@ -64,12 +66,14 @@ let system = result.system; # That build by the cross compiler - buildInputs = []; - propagatedBuildInputs = []; + buildInputs = lib.optionals (crossConfig != null) buildInputs; + propagatedBuildInputs = lib.optionals (crossConfig != null) + propagatedBuildInputs; # That build by the usual native compiler - buildNativeInputs = buildInputs ++ buildNativeInputs; - propagatedBuildNativeInputs = propagatedBuildInputs ++ - propagatedBuildNativeInputs; + buildNativeInputs = buildNativeInputs ++ lib.optionals + (crossConfig == null) buildInputs; + propagatedBuildNativeInputs = propagatedBuildNativeInputs ++ + lib.optionals (crossConfig == null) propagatedBuildInputs; })) ) # The meta attribute is passed in the resulting attribute set, diff --git a/pkgs/stdenv/generic/setup.sh b/pkgs/stdenv/generic/setup.sh index 62d441439d88..631182f6b7c3 100644 --- a/pkgs/stdenv/generic/setup.sh +++ b/pkgs/stdenv/generic/setup.sh @@ -124,6 +124,7 @@ if test -z "$SHELL"; then echo "SHELL not set"; exit 1; fi # Hack: run gcc's setup hook. envHooks=() +crossEnvHooks=() if test -f $NIX_GCC/nix-support/setup-hook; then source $NIX_GCC/nix-support/setup-hook fi @@ -203,10 +204,16 @@ for i in $nativePkgs; do addToNativeEnv $i done -crossEnvHooks=() addToCrossEnv() { local pkg=$1 + # Some programs put important build scripts (freetype-config and similar) + # into their hostDrv bin path. Intentionally these should go after + # the nativePkgs in PATH. + if test -d $1/bin; then + addToSearchPath _PATH $1/bin + fi + # Run the package-specific hooks set by the setup-hook scripts. for i in "${crossEnvHooks[@]}"; do $i $pkg |