From 86b097432aef616552715f3f2ef6d183aee6da22 Mon Sep 17 00:00:00 2001 From: Alexey Lebedeff Date: Fri, 27 Jul 2018 10:41:42 +0200 Subject: [PATCH] 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 --- pkgs/os-specific/linux/procps-ng/default.nix | 16 ++++++++++++++-- 1 file 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 7f1e93c072da..dd269c447df8 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" ];