postgresql: Make systemd support configurable. See #61580. (#61581)

On by default, as was before.

The systemd dependency means that all libraries or applications using only libpq
will also pull systemd into their closures.

Further, no application or library using libpq can be built against musl, as
systemd relies on glibc-only features and thus does not build with musl.

With it being configurable, packages that need only the library can at
least turn it off to reduce their closure size.
This commit is contained in:
Niklas Hambüchen 2019-07-21 21:13:06 +02:00 committed by Danylo Hlynskyi
parent caa0f82bf8
commit 943baed788
1 changed files with 5 additions and 2 deletions

View File

@ -6,6 +6,9 @@ let
, glibc, zlib, readline, openssl, icu, systemd, libossp_uuid , glibc, zlib, readline, openssl, icu, systemd, libossp_uuid
, pkgconfig, libxml2, tzdata , pkgconfig, libxml2, tzdata
# This is important to obtain a version of `libpq` that does not depend on systemd.
, enableSystemd ? (lib.versionAtLeast "9.6" version && !stdenv.isDarwin)
# for postgreql.pkgs # for postgreql.pkgs
, this, self, newScope, buildEnv , this, self, newScope, buildEnv
@ -31,7 +34,7 @@ let
buildInputs = buildInputs =
[ zlib readline openssl libxml2 makeWrapper ] [ zlib readline openssl libxml2 makeWrapper ]
++ lib.optionals icuEnabled [ icu ] ++ lib.optionals icuEnabled [ icu ]
++ lib.optionals (atLeast "9.6" && !stdenv.isDarwin) [ systemd ] ++ lib.optionals enableSystemd [ systemd ]
++ lib.optionals (!stdenv.isDarwin) [ libossp_uuid ]; ++ lib.optionals (!stdenv.isDarwin) [ libossp_uuid ];
nativeBuildInputs = lib.optionals icuEnabled [ pkgconfig ]; nativeBuildInputs = lib.optionals icuEnabled [ pkgconfig ];
@ -51,7 +54,7 @@ let
"--sysconfdir=/etc" "--sysconfdir=/etc"
"--libdir=$(lib)/lib" "--libdir=$(lib)/lib"
"--with-system-tzdata=${tzdata}/share/zoneinfo" "--with-system-tzdata=${tzdata}/share/zoneinfo"
(lib.optionalString (atLeast "9.6" && !stdenv.isDarwin) "--with-systemd") (lib.optionalString enableSystemd "--with-systemd")
(if stdenv.isDarwin then "--with-uuid=e2fs" else "--with-ossp-uuid") (if stdenv.isDarwin then "--with-uuid=e2fs" else "--with-ossp-uuid")
] ++ lib.optionals icuEnabled [ "--with-icu" ]; ] ++ lib.optionals icuEnabled [ "--with-icu" ];