2021-01-23 12:26:19 +00:00
|
|
|
{lib, stdenv, fetchurl}:
|
2004-03-05 10:13:23 +00:00
|
|
|
|
2009-02-05 16:49:41 +00:00
|
|
|
stdenv.mkDerivation rec {
|
2017-01-16 23:13:18 +00:00
|
|
|
name = "gperf-3.1";
|
2009-02-05 16:49:41 +00:00
|
|
|
|
2004-03-05 10:13:23 +00:00
|
|
|
src = fetchurl {
|
2009-02-05 16:49:41 +00:00
|
|
|
url = "mirror://gnu/gperf/${name}.tar.gz";
|
2017-01-16 23:13:18 +00:00
|
|
|
sha256 = "1qispg6i508rq8pkajh26cznwimbnj06wq9sd85vg95v8nwld1aq";
|
2009-02-05 16:49:41 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
meta = {
|
2014-08-24 14:21:08 +00:00
|
|
|
description = "Perfect hash function generator";
|
2009-02-05 16:49:41 +00:00
|
|
|
|
|
|
|
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.
|
|
|
|
'';
|
|
|
|
|
2021-01-23 12:26:19 +00:00
|
|
|
license = lib.licenses.gpl3Plus;
|
2009-02-05 16:49:41 +00:00
|
|
|
|
2020-04-01 01:11:51 +00:00
|
|
|
homepage = "https://www.gnu.org/software/gperf/";
|
2021-01-23 12:26:19 +00:00
|
|
|
platforms = lib.platforms.unix;
|
2004-03-05 10:13:23 +00:00
|
|
|
};
|
|
|
|
}
|