2018-08-20 20:43:41 +02:00
|
|
|
{ stdenv, fetchurl, m4, cxx ? !stdenv.hostPlatform.useAndroidPrebuilt
|
|
|
|
, buildPackages
|
2017-04-26 05:52:53 +02:00
|
|
|
, withStatic ? false }:
|
2015-03-26 06:59:04 +01:00
|
|
|
|
2017-02-09 02:52:13 +01:00
|
|
|
let inherit (stdenv.lib) optional optionalString; in
|
2015-03-26 06:59:04 +01:00
|
|
|
|
2015-10-15 17:43:23 +02:00
|
|
|
let self = stdenv.mkDerivation rec {
|
2017-04-11 11:53:37 +02:00
|
|
|
name = "gmp-6.1.2";
|
2015-03-26 06:59:04 +01:00
|
|
|
|
|
|
|
src = fetchurl { # we need to use bz2, others aren't in bootstrapping stdenv
|
|
|
|
urls = [ "mirror://gnu/gmp/${name}.tar.bz2" "ftp://ftp.gmplib.org/pub/${name}/${name}.tar.bz2" ];
|
2017-04-11 11:53:37 +02:00
|
|
|
sha256 = "1clg7pbpk6qwxj5b2mw0pghzawp2qlm3jf9gdd8i6fl6yh2bnxaj";
|
2015-03-26 06:59:04 +01:00
|
|
|
};
|
|
|
|
|
2016-04-17 14:32:35 +02:00
|
|
|
#outputs TODO: split $cxx due to libstdc++ dependency
|
2015-10-28 11:34:02 +01:00
|
|
|
# maybe let ghc use a version with *.so shared with rest of nixpkgs and *.a added
|
|
|
|
# - see #5855 for related discussion
|
2016-08-29 02:30:01 +02:00
|
|
|
outputs = [ "out" "dev" "info" ];
|
2015-10-15 17:43:23 +02:00
|
|
|
passthru.static = self.out;
|
2015-10-28 11:34:02 +01:00
|
|
|
|
2017-06-26 05:10:03 +02:00
|
|
|
depsBuildBuild = [ buildPackages.stdenv.cc ];
|
|
|
|
nativeBuildInputs = [ m4 ];
|
2015-03-26 06:59:04 +01:00
|
|
|
|
2018-08-03 17:58:20 +02:00
|
|
|
configureFlags = [
|
|
|
|
"--with-pic"
|
|
|
|
(stdenv.lib.enableFeature cxx "cxx")
|
2015-03-26 06:59:04 +01:00
|
|
|
# Build a "fat binary", with routines for several sub-architectures
|
|
|
|
# (x86), except on Solaris where some tests crash with "Memory fault".
|
|
|
|
# See <http://hydra.nixos.org/build/2760931>, for instance.
|
|
|
|
#
|
|
|
|
# no darwin because gmp uses ASM that clang doesn't like
|
2018-08-03 17:58:20 +02:00
|
|
|
(stdenv.lib.enableFeature (!stdenv.isSunOS && stdenv.hostPlatform.isx86) "fat")
|
2018-11-30 00:52:55 +01:00
|
|
|
# The config.guess in GMP tries to runtime-detect various
|
|
|
|
# ARM optimization flags via /proc/cpuinfo (and is also
|
|
|
|
# broken on multicore CPUs). Avoid this impurity.
|
|
|
|
"--build=${stdenv.buildPlatform.config}"
|
2018-08-03 17:58:20 +02:00
|
|
|
] ++ optional (cxx && stdenv.isDarwin) "CPPFLAGS=-fexceptions"
|
2018-06-14 21:44:26 +02:00
|
|
|
++ optional (stdenv.isDarwin && stdenv.is64bit) "ABI=64"
|
|
|
|
++ optional (with stdenv.hostPlatform; useAndroidPrebuilt || useiOSPrebuilt) "--disable-assembly"
|
2015-03-26 06:59:04 +01:00
|
|
|
;
|
|
|
|
|
2018-01-08 08:19:47 +01:00
|
|
|
doCheck = true; # not cross;
|
2015-03-26 06:59:04 +01:00
|
|
|
|
|
|
|
dontDisableStatic = withStatic;
|
|
|
|
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
|
|
|
meta = with stdenv.lib; {
|
2017-08-02 23:50:51 +02:00
|
|
|
homepage = https://gmplib.org/;
|
2015-03-26 06:59:04 +01:00
|
|
|
description = "GNU multiple precision arithmetic library";
|
|
|
|
license = licenses.gpl3Plus;
|
|
|
|
|
|
|
|
longDescription =
|
|
|
|
'' GMP is a free library for arbitrary precision arithmetic, operating
|
|
|
|
on signed integers, rational numbers, and floating point numbers.
|
|
|
|
There is no practical limit to the precision except the ones implied
|
|
|
|
by the available memory in the machine GMP runs on. GMP has a rich
|
|
|
|
set of functions, and the functions have a regular interface.
|
|
|
|
|
|
|
|
The main target applications for GMP are cryptography applications
|
|
|
|
and research, Internet security applications, algebra systems,
|
|
|
|
computational algebra research, etc.
|
|
|
|
|
|
|
|
GMP is carefully designed to be as fast as possible, both for small
|
|
|
|
operands and for huge operands. The speed is achieved by using
|
|
|
|
fullwords as the basic arithmetic type, by using fast algorithms,
|
|
|
|
with highly optimised assembly code for the most common inner loops
|
|
|
|
for a lot of CPUs, and by a general emphasis on speed.
|
|
|
|
|
|
|
|
GMP is faster than any other bignum library. The advantage for GMP
|
|
|
|
increases with the operand sizes for many operations, since GMP uses
|
|
|
|
asymptotically faster algorithms.
|
|
|
|
'';
|
|
|
|
|
|
|
|
platforms = platforms.all;
|
2016-07-07 05:22:15 +02:00
|
|
|
maintainers = [ maintainers.peti maintainers.vrthra ];
|
2015-03-26 06:59:04 +01:00
|
|
|
};
|
2015-10-15 17:43:23 +02:00
|
|
|
};
|
|
|
|
in self
|