2018-02-18 12:11:06 +00:00
|
|
|
{ fetchurl, fetchpatch, stdenv, gmpxx, perl, gnum4 }:
|
2011-12-14 14:31:56 +00:00
|
|
|
|
2017-08-26 12:58:04 +01:00
|
|
|
let version = "1.2"; in
|
2011-12-14 14:31:56 +00:00
|
|
|
|
2019-08-13 22:52:01 +01:00
|
|
|
stdenv.mkDerivation {
|
2019-08-13 22:52:01 +01:00
|
|
|
pname = "ppl";
|
|
|
|
inherit version;
|
2011-12-14 14:31:56 +00:00
|
|
|
|
|
|
|
src = fetchurl {
|
|
|
|
url = "http://bugseng.com/products/ppl/download/ftp/releases/${version}/ppl-${version}.tar.bz2";
|
2017-08-26 12:58:04 +01:00
|
|
|
sha256 = "1wgxcbgmijgk11df43aiqfzv31r3bkxmgb4yl68g21194q60nird";
|
2011-12-14 14:31:56 +00:00
|
|
|
};
|
|
|
|
|
2018-02-18 12:11:06 +00:00
|
|
|
patches = [(fetchpatch {
|
|
|
|
name = "ppl.patch";
|
|
|
|
url = "http://www.cs.unipr.it/git/gitweb.cgi?p=ppl/ppl.git;a=patch;h=c39f6a07b51f89e365b05ba4147aa2aa448febd7";
|
|
|
|
sha256 = "1zj90hm25pkgvk4jlkfzh18ak9b98217gbidl3731fdccbw6hr87";
|
|
|
|
})];
|
|
|
|
|
2012-12-28 18:20:09 +00:00
|
|
|
nativeBuildInputs = [ perl gnum4 ];
|
2011-12-14 14:31:56 +00:00
|
|
|
propagatedBuildInputs = [ gmpxx ];
|
|
|
|
|
2014-06-01 19:46:33 +01:00
|
|
|
configureFlags = [ "--disable-watchdog" ] ++
|
2014-05-28 07:35:31 +01:00
|
|
|
stdenv.lib.optionals stdenv.isDarwin [
|
2014-06-01 19:46:33 +01:00
|
|
|
"CPPFLAGS=-fexceptions"
|
2014-05-28 07:35:31 +01:00
|
|
|
"--disable-ppl_lcdd" "--disable-ppl_lpsol" "--disable-ppl_pips"
|
|
|
|
];
|
2011-12-14 14:31:56 +00:00
|
|
|
|
|
|
|
# Beware! It took ~6 hours to compile PPL and run its tests on a 1.2 GHz
|
|
|
|
# x86_64 box. Nevertheless, being a dependency of GCC, it probably ought
|
|
|
|
# to be tested.
|
|
|
|
doCheck = false;
|
|
|
|
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
|
|
|
meta = {
|
2014-08-24 15:21:08 +01:00
|
|
|
description = "The Parma Polyhedra Library";
|
2011-12-14 14:31:56 +00:00
|
|
|
|
|
|
|
longDescription = ''
|
|
|
|
The Parma Polyhedra Library (PPL) provides numerical abstractions
|
|
|
|
especially targeted at applications in the field of analysis and
|
|
|
|
verification of complex systems. These abstractions include convex
|
|
|
|
polyhedra, defined as the intersection of a finite number of (open or
|
|
|
|
closed) halfspaces, each described by a linear inequality (strict or
|
|
|
|
non-strict) with rational coefficients; some special classes of
|
|
|
|
polyhedra shapes that offer interesting complexity/precision tradeoffs;
|
|
|
|
and grids which represent regularly spaced points that satisfy a set of
|
|
|
|
linear congruence relations. The library also supports finite
|
|
|
|
powersets and products of (any kind of) polyhedra and grids and a mixed
|
|
|
|
integer linear programming problem solver using an exact-arithmetic
|
|
|
|
version of the simplex algorithm.
|
|
|
|
'';
|
|
|
|
|
2013-02-20 09:20:07 +00:00
|
|
|
homepage = http://bugseng.com/products/ppl/;
|
2011-12-14 14:31:56 +00:00
|
|
|
|
2014-06-19 05:19:00 +01:00
|
|
|
license = stdenv.lib.licenses.gpl3Plus;
|
2011-12-14 14:31:56 +00:00
|
|
|
|
2013-08-16 22:44:33 +01:00
|
|
|
maintainers = [ ];
|
2016-08-02 18:50:55 +01:00
|
|
|
platforms = stdenv.lib.platforms.unix;
|
2011-12-14 14:31:56 +00:00
|
|
|
};
|
|
|
|
}
|