Files
Dark Steveneq 646b892680
Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
push sheeet
2025-10-09 14:15:47 +02:00

48 lines
1.2 KiB
Nix

{
buildDunePackage,
fetchFromGitHub,
lib,
printbox-text,
reason,
}:
buildDunePackage {
pname = "reperf";
version = "1.5.1";
src = fetchFromGitHub {
owner = "bryphe";
repo = "reperf";
rev = "68ef2f96899c09e6ac7d929b0375f7a806aee067";
sha256 = "sha256-ASujTsH4eDAYLNalB9Xt1p3C8x+FI0kMldZBYaXMCWc=";
};
postPatch = ''
substituteInPlace src/dune --replace "printbox" "printbox-text"
'';
nativeBuildInputs = [ reason ];
propagatedBuildInputs = [
printbox-text
];
meta = with lib; {
description = "Native Reason + JSOO cross-platform performance benchmarking tools";
longDescription = ''
Inspired by the core_bench tools from Janestreet.
reperf helps with:
* Timing: time spent in a code block
* Call count: frequency of code-path calls
* Allocations: code-block impact to garbage collector
Supports benchmarks, which are test cases that exercise performance scenarios.
Outputs a JSON performance report, and compare it with previous iterations - and fail if a regression is detected.
'';
homepage = "https://github.com/bryphe/reperf";
maintainers = [ ];
license = licenses.mit;
};
}