summary refs log blame commit diff
path: root/pkgs/development/libraries/ppl/default.nix
blob: d8ffde644de1a42b080eef5287f27d8777336c65 (plain) (tree)
1
2
3
4
5
6
7
8
9
10
                                                         
 
   

                                                                                              
  



                            
                                                                
                                                                      

      
                                       

                                      


                                                       


                                                                             
                    

























                                                                               
{ fetchurl, stdenv, gmpxx, perl, gnum4, static ? false }:

let
  version = "0.11";
  staticFlags = if static then " --enable-static --disable-shared --disable-watchdog" else "";
in
  stdenv.mkDerivation rec {
    name = "ppl-${version}";

    src = fetchurl {
      url = "mirror://gcc/infrastructure/ppl-${version}.tar.gz";
      sha256 = "0xqwyaj232gi0pgm6z2rihk6p8l1rngbbibnhmcrbq4jq550clrl";
    };

    buildNativeInputs = [ perl gnum4 ];
    propagatedBuildInputs = [ gmpxx ];

    dontDisableStatic = if static then true else false;
    configureFlags = staticFlags;

    # 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;

    meta = {
      description = "PPL: The Parma Polyhedra Library";

      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.
      '';

      homepage = http://www.cs.unipr.it/ppl/;

      license = "GPLv3+";

      maintainers = [ stdenv.lib.maintainers.ludo ];
    };
  }