2018-12-03 15:49:12 +00:00
|
|
|
{stdenv, fetchurl, autoreconfHook }:
|
2017-01-18 15:45:52 +00:00
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
|
|
|
name = "gperf-3.0.4";
|
|
|
|
|
|
|
|
src = fetchurl {
|
|
|
|
url = "mirror://gnu/gperf/${name}.tar.gz";
|
|
|
|
sha256 = "0gnnm8iqcl52m8iha3sxrzrl9mcyhg7lfrhhqgdn4zj00ji14wbn";
|
|
|
|
};
|
|
|
|
|
2018-12-03 15:49:12 +00:00
|
|
|
nativeBuildInputs = [ autoreconfHook ];
|
|
|
|
patches = [ ./gperf-ar-fix.patch ];
|
2017-01-18 15:45:52 +00:00
|
|
|
meta = {
|
|
|
|
description = "Perfect hash function generator";
|
|
|
|
|
|
|
|
longDescription = ''
|
|
|
|
GNU gperf is a perfect hash function generator. For a given
|
|
|
|
list of strings, it produces a hash function and hash table, in
|
|
|
|
form of C or C++ code, for looking up a value depending on the
|
|
|
|
input string. The hash function is perfect, which means that
|
|
|
|
the hash table has no collisions, and the hash table lookup
|
|
|
|
needs a single string comparison only.
|
|
|
|
|
|
|
|
GNU gperf is highly customizable. There are options for
|
|
|
|
generating C or C++ code, for emitting switch statements or
|
|
|
|
nested ifs instead of a hash table, and for tuning the algorithm
|
|
|
|
employed by gperf.
|
|
|
|
'';
|
|
|
|
|
|
|
|
license = stdenv.lib.licenses.gpl3Plus;
|
|
|
|
|
2020-04-01 02:11:51 +01:00
|
|
|
homepage = "https://www.gnu.org/software/gperf/";
|
2017-01-18 15:45:52 +00:00
|
|
|
platforms = stdenv.lib.platforms.unix;
|
|
|
|
};
|
|
|
|
}
|