depot/third_party/nixpkgs/pkgs/by-name/pp/pprof/package.nix

51 lines
1.7 KiB
Nix

{
lib,
buildGoModule,
fetchFromGitHub,
}:
buildGoModule rec {
pname = "pprof";
version = "0-unstable-2024-09-25";
src = fetchFromGitHub {
owner = "google";
repo = "pprof";
rev = "fa3061bff0bcf0d611f07dbdba73665bd2bbac97";
hash = "sha256-wUHCbgmJI3YTettVVrLnRPIexaHuAQDmbnHXPTLBBYM=";
};
postPatch = ''
rm -rf browsertests # somewhat independent module to ignore.
'';
vendorHash = "sha256-oOjkjVb3OIGMwz3/85KTewXISpBZM3o1BfFG9aysFbo=";
meta = with lib; {
description = "Tool for visualization and analysis of profiling data";
homepage = "https://github.com/google/pprof";
license = licenses.asl20;
longDescription = ''
pprof reads a collection of profiling samples in profile.proto format and
generates reports to visualize and help analyze the data. It can generate
both text and graphical reports (through the use of the dot visualization
package).
profile.proto is a protocol buffer that describes a set of callstacks and
symbolization information. A common usage is to represent a set of sampled
callstacks from statistical profiling. The format is described on the
proto/profile.proto file. For details on protocol buffers, see
https://developers.google.com/protocol-buffers
Profiles can be read from a local file, or over http. Multiple profiles of
the same type can be aggregated or compared.
If the profile samples contain machine addresses, pprof can symbolize them
through the use of the native binutils tools (addr2line and nm).
This is not an official Google product.
'';
mainProgram = "pprof";
maintainers = with maintainers; [ hzeller ];
};
}