crypto++: fix tests by not using -O3, refactor
Tests were segfaulting due to compilation with -O3, most likely since building with gcc-4.9. AFAIK it isn't generally safe/advisable to use -O3 anyway. Also do some cleanup and expression refactoring, mostly.
This commit is contained in:
parent
12102562f7
commit
637873d8fb
@ -1,4 +1,4 @@
|
|||||||
{ fetchurl, stdenv, unzip, libtool }:
|
{ fetchurl, stdenv, unzip }:
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "crypto++-5.6.2";
|
name = "crypto++-5.6.2";
|
||||||
@ -8,45 +8,38 @@ stdenv.mkDerivation rec {
|
|||||||
sha256 = "0x1mqpz1v071cfrw4grbw7z734cxnpry1qh2b6rsmcx6nkyd5gsw";
|
sha256 = "0x1mqpz1v071cfrw4grbw7z734cxnpry1qh2b6rsmcx6nkyd5gsw";
|
||||||
};
|
};
|
||||||
|
|
||||||
patches = (stdenv.lib.optional (stdenv.system != "i686-cygwin") ./dll.patch)
|
patches = with stdenv;
|
||||||
++ (stdenv.lib.optional stdenv.isDarwin ./GNUmakefile.patch);
|
lib.optional (system != "i686-cygwin") ./dll.patch
|
||||||
|
++ lib.optional isDarwin ./GNUmakefile.patch;
|
||||||
|
|
||||||
buildInputs = [ unzip libtool ];
|
buildInputs = [ unzip ];
|
||||||
|
|
||||||
# Unpack the thing in a subdirectory.
|
sourceRoot = ".";
|
||||||
unpackPhase = ''
|
|
||||||
echo "unpacking Crypto++ to \`${name}' from \`$PWD'..."
|
|
||||||
mkdir "${name}" && (cd "${name}" && unzip "$src")
|
|
||||||
sourceRoot="$PWD/${name}"
|
|
||||||
'';
|
|
||||||
|
|
||||||
cxxflags = if stdenv.isi686 then "-march=i686" else
|
configurePhase = let
|
||||||
if stdenv.isx86_64 then "-march=nocona -fPIC" else
|
marchflags =
|
||||||
"";
|
if stdenv.isi686 then "-march=i686" else
|
||||||
|
if stdenv.isx86_64 then "-march=nocona -mtune=generic" else
|
||||||
|
"";
|
||||||
|
in
|
||||||
|
''
|
||||||
|
sed -i GNUmakefile \
|
||||||
|
-e 's|-march=native|${marchflags} -fPIC|g' \
|
||||||
|
-e 's|-mtune=native||g' \
|
||||||
|
-e '/^CXXFLAGS =/s|-g ||'
|
||||||
|
'';
|
||||||
|
|
||||||
configurePhase = ''
|
enableParallelBuilding = true;
|
||||||
sed -i GNUmakefile \
|
|
||||||
-e 's|-march=native|${cxxflags}|g' \
|
|
||||||
-e 's|-mtune=native||g' \
|
|
||||||
-e '/^CXXFLAGS =/s|-g -O2|-O3|'
|
|
||||||
'';
|
|
||||||
|
|
||||||
# I add what 'enableParallelBuilding' would add to the make call,
|
makeFlags = "PREFIX=$(out)";
|
||||||
# if we were using the generic build phase.
|
buildFlags = "libcryptopp.so";
|
||||||
buildPhase = ''
|
|
||||||
make PREFIX="$out" all libcryptopp.so -j$NIX_BUILD_CORES -l$NIX_BUILD_CORES
|
|
||||||
'';
|
|
||||||
|
|
||||||
# TODO: Installing cryptotest.exe doesn't seem to be necessary. We run
|
|
||||||
# that binary during this build anyway to verify everything works.
|
|
||||||
installPhase = ''
|
|
||||||
mkdir "$out"
|
|
||||||
make install PREFIX="$out"
|
|
||||||
'';
|
|
||||||
|
|
||||||
doCheck = true;
|
doCheck = true;
|
||||||
checkPhase = "LD_LIBRARY_PATH=`pwd` make test";
|
checkPhase = "LD_LIBRARY_PATH=`pwd` make test";
|
||||||
|
|
||||||
|
# prefer -fPIC and .so to .a; cryptotest.exe seems superfluous
|
||||||
|
postInstall = ''rm "$out"/lib/*.a -r "$out/bin" '';
|
||||||
|
|
||||||
meta = with stdenv.lib; {
|
meta = with stdenv.lib; {
|
||||||
description = "Crypto++, a free C++ class library of cryptographic schemes";
|
description = "Crypto++, a free C++ class library of cryptographic schemes";
|
||||||
homepage = http://cryptopp.com/;
|
homepage = http://cryptopp.com/;
|
||||||
@ -55,3 +48,4 @@ stdenv.mkDerivation rec {
|
|||||||
maintainers = [ ];
|
maintainers = [ ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user