From aa1b96ff78b59878cee48bce2cdbc974568e8f6c Mon Sep 17 00:00:00 2001 From: Ben Wolsieffer Date: Sun, 18 Sep 2022 22:30:51 -0400 Subject: [PATCH] boost: enable cross-compiling Boost.Python Explicitly tell Boost where to find Python, so Boost.Python can build be cross- compiled. --- pkgs/development/libraries/boost/generic.nix | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/pkgs/development/libraries/boost/generic.nix b/pkgs/development/libraries/boost/generic.nix index b6ab49e4b4d9..bea3f007e631 100644 --- a/pkgs/development/libraries/boost/generic.nix +++ b/pkgs/development/libraries/boost/generic.nix @@ -207,6 +207,15 @@ stdenv.mkDerivation { $RANLIB ; EOF + '' + # b2 needs to be explicitly told how to find Python when cross-compiling + + optionalString enablePython '' + cat << EOF >> user-config.jam + using python : : ${python.interpreter} + : ${python}/include/python${python.pythonVersion} + : ${python}/lib + ; + EOF ''; NIX_CFLAGS_LINK = lib.optionalString stdenv.isDarwin @@ -229,8 +238,7 @@ stdenv.mkDerivation { "--includedir=$(dev)/include" "--libdir=$(out)/lib" "--with-bjam=b2" # prevent bootstrapping b2 in configurePhase - ] ++ optional enablePython "--with-python=${python.interpreter}" - ++ optional (toolset != null) "--with-toolset=${toolset}" + ] ++ optional (toolset != null) "--with-toolset=${toolset}" ++ [ (if stdenv.hostPlatform == stdenv.buildPlatform then "--with-icu=${icu.dev}" else "--without-icu") ]; buildPhase = ''