From 7ba046d9065c65a7da063e8148ceae169abac508 Mon Sep 17 00:00:00 2001 From: Francesco Gazzetta Date: Mon, 15 Apr 2019 22:20:13 +0000 Subject: [PATCH] drawpile: add build options (#57573) Also add server-headless variant --- .../graphics/drawpile/default.nix | 97 +++++++++++++------ pkgs/top-level/all-packages.nix | 4 + 2 files changed, 73 insertions(+), 28 deletions(-) diff --git a/pkgs/applications/graphics/drawpile/default.nix b/pkgs/applications/graphics/drawpile/default.nix index 8c547359820..6c354ebe37d 100644 --- a/pkgs/applications/graphics/drawpile/default.nix +++ b/pkgs/applications/graphics/drawpile/default.nix @@ -1,48 +1,89 @@ { stdenv , fetchurl , cmake -, qtbase -, qtsvg -, qtmultimedia -, qttools -, kdnssd -, karchive -, libsodium -, libmicrohttpd -, giflib -, miniupnpc , extra-cmake-modules + +# common deps +, karchive + +# client deps +, qtbase +, qtmultimedia +, qtsvg +, qttools + +# optional client deps +, giflib +, kdnssd , libvpx +, miniupnpc +, qtx11extras # kis + +# optional server deps +, libmicrohttpd +, libsodium + +# options +, buildClient ? true +, buildServer ? true +, buildServerGui ? true # if false builds a headless server +, buildExtraTools ? false +, enableKisTablet ? false # enable improved graphics tablet support }: -stdenv.mkDerivation rec { +with stdenv.lib; + +let + commonDeps = [ + karchive + ]; + clientDeps = [ + qtbase + qtmultimedia + qtsvg + qttools + # optional: + giflib # gif animation export support + kdnssd # local server discovery with Zeroconf + libvpx # WebM video export + miniupnpc # automatic port forwarding + ]; + serverDeps = [ + # optional: + libmicrohttpd # HTTP admin api + libsodium # ext-auth support + ]; + kisDeps = [ + qtx11extras + ]; + +in stdenv.mkDerivation rec { name = "drawpile-${version}"; version = "2.1.6"; + src = fetchurl { url = "https://drawpile.net/files/src/drawpile-${version}.tar.gz"; sha256 = "0vwsdvphigrq1daiazi411qflahlvgx8x8ssp581bng2lbq1vrbd"; }; + nativeBuildInputs = [ + cmake extra-cmake-modules ]; - buildInputs = [ - # common deps: - cmake - qtbase qtsvg qtmultimedia qttools - karchive - # optional deps: - # server-specific: - libsodium # ext-auth support - libmicrohttpd # HTTP admin api - # client-specific: - giflib # gif animation export support - miniupnpc # automatic port forwarding - kdnssd # local server discovery with Zeroconf - libvpx # WebM video export - ]; - configurePhase = "cmake -DCMAKE_INSTALL_PREFIX=$out ."; + buildInputs = + commonDeps ++ + optionals buildClient clientDeps ++ + optionals buildServer serverDeps ++ + optionals enableKisTablet kisDeps ; - meta = with stdenv.lib; { + cmakeFlags = + optional (!buildClient ) "-DCLIENT=off" ++ + optional (!buildServer ) "-DSERVER=off" ++ + optional (!buildServerGui ) "-DSERVERGUI=off" ++ + optional ( buildExtraTools) "-DTOOLS=on" ++ + optional ( enableKisTablet) "-DKIS_TABLET=on"; + + meta = { description = "A collaborative drawing program that allows multiple users to sketch on the same canvas simultaneously"; homepage = https://drawpile.net/; downloadPage = https://drawpile.net/download/; diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix index e70651de84c..c263d011b5a 100644 --- a/pkgs/top-level/all-packages.nix +++ b/pkgs/top-level/all-packages.nix @@ -16990,6 +16990,10 @@ in dragonfly-reverb = callPackage ../applications/audio/dragonfly-reverb { }; drawpile = libsForQt5.callPackage ../applications/graphics/drawpile { }; + drawpile-server-headless = libsForQt5.callPackage ../applications/graphics/drawpile { + buildClient = false; + buildServerGui = false; + }; droopy = callPackage ../applications/networking/droopy { inherit (python3Packages) wrapPython;