56 lines
1.4 KiB
Nix
56 lines
1.4 KiB
Nix
{
|
|
lib,
|
|
cmake,
|
|
fetchFromGitHub,
|
|
gitUpdater,
|
|
stdenv,
|
|
primecount,
|
|
}:
|
|
|
|
stdenv.mkDerivation (finalAttrs: {
|
|
pname = "primesieve";
|
|
version = "12.4";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "kimwalisch";
|
|
repo = "primesieve";
|
|
rev = "v${finalAttrs.version}";
|
|
hash = "sha256-3iVQsksnyw9KFBTYsmyZ6YxYICVq1GzOzemDBpqpU3M=";
|
|
};
|
|
|
|
outputs = [
|
|
"out"
|
|
"dev"
|
|
"lib"
|
|
"man"
|
|
];
|
|
|
|
nativeBuildInputs = [ cmake ];
|
|
|
|
strictDeps = true;
|
|
|
|
passthru = {
|
|
tests = {
|
|
inherit primecount; # dependent
|
|
};
|
|
updateScript = gitUpdater { rev-prefix = "v"; };
|
|
};
|
|
|
|
meta = {
|
|
homepage = "https://primesieve.org/";
|
|
description = "Fast C/C++ prime number generator";
|
|
longDescription = ''
|
|
primesieve is a command-line program and C/C++ library for quickly
|
|
generating prime numbers. It is very cache efficient, it detects your
|
|
CPU's L1 & L2 cache sizes and allocates its main data structures
|
|
accordingly. It is also multi-threaded by default, it uses all available
|
|
CPU cores whenever possible i.e. if sequential ordering is not
|
|
required. primesieve can generate primes and prime k-tuplets up to 264.
|
|
'';
|
|
changelog = "https://github.com/kimwalisch/primesieve/blob/${finalAttrs.src.rev}/ChangeLog";
|
|
license = lib.licenses.bsd2;
|
|
mainProgram = "primesieve";
|
|
maintainers = lib.teams.sage.members;
|
|
platforms = lib.platforms.unix;
|
|
};
|
|
})
|