igprof: init at v5.9.16

This commit is contained in:
Giulio Eulisse 2019-05-19 16:12:41 +02:00
parent 3bfa5d4077
commit d5e89b50b2
No known key found for this signature in database
GPG Key ID: C56A25BB35672EFB
2 changed files with 45 additions and 0 deletions

View File

@ -0,0 +1,43 @@
{stdenv, fetchFromGitHub, libunwind, cmake, pcre, gdb}:
stdenv.mkDerivation rec {
version = "5.9.16";
name = "igprof-${version}";
src = fetchFromGitHub {
owner = "igprof";
repo = "igprof";
rev = "v${version}";
sha256 = "0rx3mv8zdh9bmcpfbzkib3d52skzfr8600gh5gv21wcsh50jnifx";
};
postPatch = ''
substituteInPlace src/igprof --replace libigprof.so $out/lib/libigprof.so
'';
buildInputs = [libunwind gdb pcre];
nativeBuildInputs = [cmake];
CXXFLAGS = ["-fPIC" "-O2" "-w" "-fpermissive"];
meta = {
description = "The Ignominous Profiler";
longDescription = ''
IgProf is a fast and light weight profiler. It correctly handles
dynamically loaded shared libraries, threads and sub-processes started by
the application. We have used it routinely with large C++ applications
consisting of many hundreds of shared libraries and thousands of symbols
from millions of source lines of code. It requires no special privileges
to run. The performance reports provide full navigable call stacks and
can be customised by applying filters. Results from any number of
profiling runs can be included. This means you can both dig into the
details and see the big picture from combined workloads.
'';
license = stdenv.lib.licenses.gpl2;
homepage = https://igprof.org/;
platforms = stdenv.lib.platforms.linux;
maintainers = with stdenv.lib.maintainers; [ ktf ];
};
}

View File

@ -23224,6 +23224,8 @@ in
igraph = callPackage ../development/libraries/igraph { };
igprof = callPackage ../development/tools/misc/igprof { };
illum = callPackage ../tools/system/illum { };
image_optim = callPackage ../applications/graphics/image_optim { inherit (nodePackages) svgo; };