boost: Clean, reducing duplication
This was motivated originally by my cross work, but that goal requires a few more commits to other things. Still, it's good to start the cleanup now / get things out of the way.
This commit is contained in:
parent
cc44e04472
commit
76b590405a
|
@ -8,7 +8,7 @@ callPackage ./generic.nix (args // rec {
|
||||||
sha256 = "1jj1aai5rdmd72g90a3pd8sw9vi32zad46xv5av8fhnr48ir6ykj";
|
sha256 = "1jj1aai5rdmd72g90a3pd8sw9vi32zad46xv5av8fhnr48ir6ykj";
|
||||||
};
|
};
|
||||||
|
|
||||||
patches = if stdenv.isCygwin then [
|
patches = stdenv.lib.optionals stdenv.isCygwin [
|
||||||
./cygwin-fedora-boost-1.50.0-fix-non-utf8-files.patch
|
./cygwin-fedora-boost-1.50.0-fix-non-utf8-files.patch
|
||||||
./cygwin-fedora-boost-1.50.0-pool.patch
|
./cygwin-fedora-boost-1.50.0-pool.patch
|
||||||
./cygwin-fedora-boost-1.57.0-mpl-print.patch
|
./cygwin-fedora-boost-1.57.0-mpl-print.patch
|
||||||
|
@ -36,5 +36,5 @@ callPackage ./generic.nix (args // rec {
|
||||||
./cygwin-1.57.0-system-cygwin.patch
|
./cygwin-1.57.0-system-cygwin.patch
|
||||||
./cygwin-1.45.0-jam-cygwin.patch
|
./cygwin-1.45.0-jam-cygwin.patch
|
||||||
./cygwin-1.50.0-jam-pep3149.patch
|
./cygwin-1.50.0-jam-pep3149.patch
|
||||||
] else null;
|
];
|
||||||
})
|
})
|
||||||
|
|
|
@ -1,18 +1,19 @@
|
||||||
{ stdenv, fetchurl, icu, expat, zlib, bzip2, python, fixDarwinDylibNames, libiconv
|
{ stdenv, fetchurl, icu, expat, zlib, bzip2, python, fixDarwinDylibNames, libiconv
|
||||||
, buildPlatform, hostPlatform
|
, which
|
||||||
, toolset ? if stdenv.cc.isClang then "clang" else null
|
, buildPackages, buildPlatform, hostPlatform
|
||||||
|
, toolset ? /**/ if stdenv.cc.isClang then "clang"
|
||||||
|
else if stdenv.cc.isGNU && hostPlatform != buildPlatform then "gcc-cross"
|
||||||
|
else null
|
||||||
, enableRelease ? true
|
, enableRelease ? true
|
||||||
, enableDebug ? false
|
, enableDebug ? false
|
||||||
, enableSingleThreaded ? false
|
, enableSingleThreaded ? false
|
||||||
, enableMultiThreaded ? true
|
, enableMultiThreaded ? true
|
||||||
, enableShared ? !(hostPlatform.libc == "msvcrt") # problems for now
|
, enableShared ? !(hostPlatform.libc == "msvcrt") # problems for now
|
||||||
, enableStatic ? !enableShared
|
, enableStatic ? !enableShared
|
||||||
, enablePIC ? false
|
|
||||||
, enableExceptions ? false
|
|
||||||
, enablePython ? hostPlatform == buildPlatform
|
, enablePython ? hostPlatform == buildPlatform
|
||||||
, enableNumpy ? false
|
, enableNumpy ? false
|
||||||
, taggedLayout ? ((enableRelease && enableDebug) || (enableSingleThreaded && enableMultiThreaded) || (enableShared && enableStatic))
|
, taggedLayout ? ((enableRelease && enableDebug) || (enableSingleThreaded && enableMultiThreaded) || (enableShared && enableStatic))
|
||||||
, patches ? null
|
, patches ? []
|
||||||
, mpi ? null
|
, mpi ? null
|
||||||
|
|
||||||
# Attributes inherit from specific versions
|
# Attributes inherit from specific versions
|
||||||
|
@ -21,8 +22,9 @@
|
||||||
}:
|
}:
|
||||||
|
|
||||||
# We must build at least one type of libraries
|
# We must build at least one type of libraries
|
||||||
assert !enableShared -> enableStatic;
|
assert enableShared || enableStatic;
|
||||||
|
|
||||||
|
# Python isn't supported when cross-compiling
|
||||||
assert enablePython -> hostPlatform == buildPlatform;
|
assert enablePython -> hostPlatform == buildPlatform;
|
||||||
assert enableNumpy -> enablePython;
|
assert enableNumpy -> enablePython;
|
||||||
|
|
||||||
|
@ -46,86 +48,41 @@ let
|
||||||
# To avoid library name collisions
|
# To avoid library name collisions
|
||||||
layout = if taggedLayout then "tagged" else "system";
|
layout = if taggedLayout then "tagged" else "system";
|
||||||
|
|
||||||
cflags = if enablePIC && enableExceptions then
|
b2Args = concatStringsSep " " ([
|
||||||
"cflags=\"-fPIC -fexceptions\" cxxflags=-fPIC linkflags=-fPIC"
|
|
||||||
else if enablePIC then
|
|
||||||
"cflags=-fPIC cxxflags=-fPIC linkflags=-fPIC"
|
|
||||||
else if enableExceptions then
|
|
||||||
"cflags=-fexceptions"
|
|
||||||
else
|
|
||||||
"";
|
|
||||||
|
|
||||||
withToolset = stdenv.lib.optionalString (toolset != null) "--with-toolset=${toolset}";
|
|
||||||
|
|
||||||
genericB2Flags = [
|
|
||||||
"--includedir=$dev/include"
|
"--includedir=$dev/include"
|
||||||
"--libdir=$out/lib"
|
"--libdir=$out/lib"
|
||||||
"-j$NIX_BUILD_CORES"
|
"-j$NIX_BUILD_CORES"
|
||||||
"--layout=${layout}"
|
"--layout=${layout}"
|
||||||
"variant=${variant}"
|
"variant=${variant}"
|
||||||
"threading=${threading}"
|
"threading=${threading}"
|
||||||
] ++ optional (link != "static") "runtime-link=${runtime-link}" ++ [
|
"runtime-link=${runtime-link}"
|
||||||
"link=${link}"
|
"link=${link}"
|
||||||
"${cflags}"
|
|
||||||
] ++ optional (variant == "release") "debug-symbols=off"
|
|
||||||
++ optional (!enablePython) "--without-python";
|
|
||||||
|
|
||||||
nativeB2Flags = [
|
|
||||||
"-sEXPAT_INCLUDE=${expat.dev}/include"
|
"-sEXPAT_INCLUDE=${expat.dev}/include"
|
||||||
"-sEXPAT_LIBPATH=${expat.out}/lib"
|
"-sEXPAT_LIBPATH=${expat.out}/lib"
|
||||||
] ++ optional (toolset != null) "toolset=${toolset}"
|
] ++ optional (variant == "release") "debug-symbols=off"
|
||||||
++ optional (mpi != null) "--user-config=user-config.jam";
|
++ optional (toolset != null) "toolset=${toolset}"
|
||||||
nativeB2Args = concatStringsSep " " (genericB2Flags ++ nativeB2Flags);
|
++ optional (mpi != null || hostPlatform != buildPlatform) "--user-config=user-config.jam"
|
||||||
|
++ optionals (hostPlatform.libc == "msvcrt") [
|
||||||
crossB2Flags = [
|
|
||||||
"-sEXPAT_INCLUDE=${expat.crossDrv}/include"
|
|
||||||
"-sEXPAT_LIBPATH=${expat.crossDrv}/lib"
|
|
||||||
"--user-config=user-config.jam"
|
|
||||||
"toolset=gcc-cross"
|
|
||||||
] ++ optionals (hostPlatform.libc == "msvcrt") [
|
|
||||||
"target-os=windows"
|
"target-os=windows"
|
||||||
"threadapi=win32"
|
"threadapi=win32"
|
||||||
"binary-format=pe"
|
"binary-format=pe"
|
||||||
"address-model=${toString hostPlatform.parsed.cpu.bits}"
|
"address-model=${toString hostPlatform.parsed.cpu.bits}"
|
||||||
"architecture=x86"
|
"architecture=x86"
|
||||||
];
|
]);
|
||||||
crossB2Args = concatStringsSep " " (genericB2Flags ++ crossB2Flags);
|
|
||||||
|
|
||||||
builder = b2Args: ''
|
|
||||||
./b2 ${b2Args}
|
|
||||||
'';
|
|
||||||
|
|
||||||
installer = b2Args: ''
|
|
||||||
# boostbook is needed by some applications
|
|
||||||
mkdir -p $dev/share/boostbook
|
|
||||||
cp -a tools/boostbook/{xsl,dtd} $dev/share/boostbook/
|
|
||||||
|
|
||||||
# Let boost install everything else
|
|
||||||
./b2 ${b2Args} install
|
|
||||||
'';
|
|
||||||
|
|
||||||
commonConfigureFlags = [
|
|
||||||
"--includedir=$(dev)/include"
|
|
||||||
"--libdir=$(out)/lib"
|
|
||||||
];
|
|
||||||
|
|
||||||
fixup = ''
|
|
||||||
# Make boost header paths relative so that they are not runtime dependencies
|
|
||||||
(
|
|
||||||
cd "$dev"
|
|
||||||
find include \( -name '*.hpp' -or -name '*.h' -or -name '*.ipp' \) \
|
|
||||||
-exec sed '1i#line 1 "{}"' -i '{}' \;
|
|
||||||
)
|
|
||||||
'' + optionalString (hostPlatform.libc == "msvcrt") ''
|
|
||||||
${stdenv.cc.targetPrefix}ranlib "$out/lib/"*.a
|
|
||||||
'';
|
|
||||||
|
|
||||||
in
|
in
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation {
|
||||||
name = "boost-${version}";
|
name = "boost-${version}";
|
||||||
|
|
||||||
inherit src patches version;
|
inherit src;
|
||||||
|
|
||||||
|
patchFlags = optionalString (hostPlatform.libc == "msvcrt") "-p0";
|
||||||
|
patches = patches ++ optional (hostPlatform.libc == "msvcrt") (fetchurl {
|
||||||
|
url = "https://svn.boost.org/trac/boost/raw-attachment/tickaet/7262/"
|
||||||
|
+ "boost-mingw.patch";
|
||||||
|
sha256 = "0s32kwll66k50w6r5np1y5g907b7lcpsjhfgr7rsw7q5syhzddyj";
|
||||||
|
});
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
homepage = http://boost.org/;
|
homepage = http://boost.org/;
|
||||||
|
@ -142,9 +99,13 @@ stdenv.mkDerivation {
|
||||||
--replace '@rpath/$(<[1]:D=)' "$out/lib/\$(<[1]:D=)";
|
--replace '@rpath/$(<[1]:D=)' "$out/lib/\$(<[1]:D=)";
|
||||||
fi;
|
fi;
|
||||||
'' + optionalString (mpi != null) ''
|
'' + optionalString (mpi != null) ''
|
||||||
cat << EOF > user-config.jam
|
cat << EOF >> user-config.jam
|
||||||
using mpi : ${mpi}/bin/mpiCC ;
|
using mpi : ${mpi}/bin/mpiCC ;
|
||||||
EOF
|
EOF
|
||||||
|
'' + optionalString (hostPlatform != buildPlatform) ''
|
||||||
|
cat << EOF >> user-config.jam
|
||||||
|
using gcc : cross : ${stdenv.cc.targetPrefix}c++ ;
|
||||||
|
EOF
|
||||||
'';
|
'';
|
||||||
|
|
||||||
NIX_CFLAGS_LINK = stdenv.lib.optionalString stdenv.isDarwin
|
NIX_CFLAGS_LINK = stdenv.lib.optionalString stdenv.isDarwin
|
||||||
|
@ -152,6 +113,7 @@ stdenv.mkDerivation {
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
|
nativeBuildInputs = [ which buildPackages.stdenv.cc ];
|
||||||
buildInputs = [ expat zlib bzip2 libiconv ]
|
buildInputs = [ expat zlib bzip2 libiconv ]
|
||||||
++ optional (hostPlatform == buildPlatform) icu
|
++ optional (hostPlatform == buildPlatform) icu
|
||||||
++ optional stdenv.isDarwin fixDarwinDylibNames
|
++ optional stdenv.isDarwin fixDarwinDylibNames
|
||||||
|
@ -159,39 +121,35 @@ stdenv.mkDerivation {
|
||||||
++ optional enableNumpy python.pkgs.numpy;
|
++ optional enableNumpy python.pkgs.numpy;
|
||||||
|
|
||||||
configureScript = "./bootstrap.sh";
|
configureScript = "./bootstrap.sh";
|
||||||
configureFlags = commonConfigureFlags
|
configurePlatforms = [];
|
||||||
++ [ "--with-python=${python.interpreter}" ]
|
configureFlags = [
|
||||||
++ optional (hostPlatform == buildPlatform) "--with-icu=${icu.dev}"
|
"--includedir=$(dev)/include"
|
||||||
++ optional (toolset != null) "--with-toolset=${toolset}";
|
"--libdir=$(out)/lib"
|
||||||
|
(if enablePython then "--with-python=${python.interpreter}" else "--without-python")
|
||||||
|
(if hostPlatform == buildPlatform then "--with-icu=${icu.dev}" else "--without-icu")
|
||||||
|
] ++ optional (toolset != null) "--with-toolset=${toolset}";
|
||||||
|
|
||||||
buildPhase = builder nativeB2Args;
|
buildPhase = ''
|
||||||
|
./b2 ${b2Args}
|
||||||
|
'';
|
||||||
|
|
||||||
installPhase = installer nativeB2Args;
|
installPhase = ''
|
||||||
|
# boostbook is needed by some applications
|
||||||
|
mkdir -p $dev/share/boostbook
|
||||||
|
cp -a tools/boostbook/{xsl,dtd} $dev/share/boostbook/
|
||||||
|
|
||||||
postFixup = fixup;
|
# Let boost install everything else
|
||||||
|
./b2 ${b2Args} install
|
||||||
|
'';
|
||||||
|
|
||||||
|
postFixup = ''
|
||||||
|
# Make boost header paths relative so that they are not runtime dependencies
|
||||||
|
find "$dev/include" \( -name '*.hpp' -or -name '*.h' -or -name '*.ipp' \) \
|
||||||
|
-exec sed '1i#line 1 "{}"' -i '{}' \;
|
||||||
|
'' + optionalString (hostPlatform.libc == "msvcrt") ''
|
||||||
|
$RANLIB "$out/lib/"*.a
|
||||||
|
'';
|
||||||
|
|
||||||
outputs = [ "out" "dev" ];
|
outputs = [ "out" "dev" ];
|
||||||
setOutputFlags = false;
|
setOutputFlags = false;
|
||||||
|
|
||||||
crossAttrs = rec {
|
|
||||||
# We want to substitute the contents of configureFlags, removing thus the
|
|
||||||
# usual --build and --host added on cross building.
|
|
||||||
preConfigure = ''
|
|
||||||
export configureFlags="--without-icu ${concatStringsSep " " commonConfigureFlags}"
|
|
||||||
cat << EOF > user-config.jam
|
|
||||||
using gcc : cross : $crossConfig-g++ ;
|
|
||||||
EOF
|
|
||||||
'';
|
|
||||||
buildPhase = builder crossB2Args;
|
|
||||||
installPhase = installer crossB2Args;
|
|
||||||
postFixup = fixup;
|
|
||||||
} // optionalAttrs (hostPlatform.libc == "msvcrt") {
|
|
||||||
patches = fetchurl {
|
|
||||||
url = "https://svn.boost.org/trac/boost/raw-attachment/ticket/7262/"
|
|
||||||
+ "boost-mingw.patch";
|
|
||||||
sha256 = "0s32kwll66k50w6r5np1y5g907b7lcpsjhfgr7rsw7q5syhzddyj";
|
|
||||||
};
|
|
||||||
|
|
||||||
patchFlags = "-p0";
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue