about summary refs log tree commit diff
path: root/pkgs/development/tools/misc
diff options
context:
space:
mode:
authorGiulio Eulisse <giulio.eulisse@cern.ch>2019-05-19 16:12:41 +0200
committerGiulio Eulisse <giulio.eulisse@cern.ch>2019-06-02 11:23:11 +0200
commitd5e89b50b252214044a231e5c971ac857b59c336 (patch)
treeff02dcd230e18c70c3d84d386a615aa8b9a4bd93 /pkgs/development/tools/misc
parent3bfa5d4077281b0d357f3bbb29d9a45cae1e5464 (diff)
downloadnixlib-d5e89b50b252214044a231e5c971ac857b59c336.tar
nixlib-d5e89b50b252214044a231e5c971ac857b59c336.tar.gz
nixlib-d5e89b50b252214044a231e5c971ac857b59c336.tar.bz2
nixlib-d5e89b50b252214044a231e5c971ac857b59c336.tar.lz
nixlib-d5e89b50b252214044a231e5c971ac857b59c336.tar.xz
nixlib-d5e89b50b252214044a231e5c971ac857b59c336.tar.zst
nixlib-d5e89b50b252214044a231e5c971ac857b59c336.zip
igprof: init at v5.9.16
Diffstat (limited to 'pkgs/development/tools/misc')
-rw-r--r--pkgs/development/tools/misc/igprof/default.nix43
1 files changed, 43 insertions, 0 deletions
diff --git a/pkgs/development/tools/misc/igprof/default.nix b/pkgs/development/tools/misc/igprof/default.nix
new file mode 100644
index 000000000000..294d1fa10dde
--- /dev/null
+++ b/pkgs/development/tools/misc/igprof/default.nix
@@ -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 ];
+  };
+}