summary refs log tree commit diff
path: root/pkgs/os-specific/linux/procps-ng/default.nix
diff options
context:
space:
mode:
authorAlexey Lebedeff <binarin@binarin.ru>2018-07-27 10:41:42 +0200
committerAlexey Lebedeff <binarin@binarin.ru>2018-07-27 10:41:42 +0200
commit86b097432aef616552715f3f2ef6d183aee6da22 (patch)
treeedc98d781acedfbeede99826feebdb0ef3f27887 /pkgs/os-specific/linux/procps-ng/default.nix
parentf8e8ecde51b49132d7f8d5adb971c0e37eddcdc2 (diff)
downloadnixpkgs-86b097432aef616552715f3f2ef6d183aee6da22.tar
nixpkgs-86b097432aef616552715f3f2ef6d183aee6da22.tar.gz
nixpkgs-86b097432aef616552715f3f2ef6d183aee6da22.tar.bz2
nixpkgs-86b097432aef616552715f3f2ef6d183aee6da22.tar.lz
nixpkgs-86b097432aef616552715f3f2ef6d183aee6da22.tar.xz
nixpkgs-86b097432aef616552715f3f2ef6d183aee6da22.tar.zst
nixpkgs-86b097432aef616552715f3f2ef6d183aee6da22.zip
procps: enable systemd support when available
`ps` can show various systemd-related information, like a unit to
which a process belongs. But when it's not compiled it, it shows only
'?' in such fields.

Can be tested with:

    ps -o unit= ax
Diffstat (limited to 'pkgs/os-specific/linux/procps-ng/default.nix')
-rw-r--r--pkgs/os-specific/linux/procps-ng/default.nix16
1 files changed, 14 insertions, 2 deletions
diff --git a/pkgs/os-specific/linux/procps-ng/default.nix b/pkgs/os-specific/linux/procps-ng/default.nix
index 7f1e93c072d..dd269c447df 100644
--- a/pkgs/os-specific/linux/procps-ng/default.nix
+++ b/pkgs/os-specific/linux/procps-ng/default.nix
@@ -1,10 +1,20 @@
 { lib, stdenv, fetchurl, ncurses, pkgconfig
 
+# `ps` with systemd support is able to properly report different
+# attributes like unit name, so we want to have it on linux.
+# The strange `boostrap` condition is here because `procps` can be
+# pulled in to early in bootstrap process, when `stdenv` is not yet
+# functional enought to build `systemd` (or its dependencies).
+# See https://github.com/NixOS/nixpkgs/pull/43817#issuecomment-408346135
+, withSystemd ? stdenv.isLinux && !(lib.hasPrefix "bootstrap" stdenv.name)
+, systemd
+
 # procps is mostly Linux-only. Most commands require a running Linux
 # system (or very similar like that found in Cygwin). The one
 # exception is ‘watch’ which is portable enough to run on pretty much
 # any UNIX-compatible system.
-, watchOnly ? !(stdenv.isLinux || stdenv.isCygwin) }:
+, watchOnly ? !(stdenv.isLinux || stdenv.isCygwin)
+}:
 
 stdenv.mkDerivation rec {
   name = "procps-${version}";
@@ -16,7 +26,8 @@ stdenv.mkDerivation rec {
     sha256 = "0r84kwa5fl0sjdashcn4vh7hgfm7ahdcysig3mcjvpmkzi7p9g8h";
   };
 
-  buildInputs = [ ncurses ];
+  buildInputs = [ ncurses ]
+    ++ lib.optional withSystemd systemd;
   nativeBuildInputs = [ pkgconfig ];
 
   makeFlags = [ "usrbin_execdir=$(out)/bin" ]
@@ -26,6 +37,7 @@ stdenv.mkDerivation rec {
 
   # Too red
   configureFlags = [ "--disable-modern-top" ]
+    ++ lib.optional withSystemd "--with-systemd"
     ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform)
     [ "ac_cv_func_malloc_0_nonnull=yes"
       "ac_cv_func_realloc_0_nonnull=yes" ];