Merge pull request #6422 from codyopel/libinput

libinput: refactor & add optional dependencies
This commit is contained in:
William A. Kennington III 2015-02-24 11:47:45 -08:00
commit dbaf941212
2 changed files with 36 additions and 9 deletions

View File

@ -1,5 +1,19 @@
{ stdenv, fetchurl, pkgconfig, mtdev, udev, libevdev }:
{ stdenv, fetchurl, pkgconfig
, libevdev, mtdev, udev
, documentationSupport ? true, doxygen ? null, graphviz ? null # Documentation
, eventGUISupport ? false, cairo ? null, glib ? null, gtk3 ? null # GUI event viewer support
, testsSupport ? false, check ? null, valgrind ? null
}:
assert documentationSupport -> doxygen != null && graphviz != null;
assert eventGUISupport -> cairo != null && glib != null && gtk3 != null;
assert testsSupport -> check != null && valgrind != null;
let
mkFlag = optSet: flag: if optSet then "--enable-${flag}" else "--disable-${flag}";
in
with stdenv.lib;
stdenv.mkDerivation rec {
name = "libinput-0.10.0";
@ -8,13 +22,24 @@ stdenv.mkDerivation rec {
sha256 = "0h8lbhhxb5020bhdblxp1pkapy4bchjj3l44fxabz9pi1zw03q2c";
};
buildInputs = [ pkgconfig mtdev udev libevdev ];
configureFlags = [
(mkFlag documentationSupport "documentation")
(mkFlag eventGUISupport "event-gui")
(mkFlag testsSupport "tests")
];
meta = with stdenv.lib; {
homepage = http://www.freedesktop.org/wiki/Software/libinput;
description = "handles input devices in Wayland compositors and to provide a generic X.Org input driver";
platforms = platforms.unix;
license = licenses.mit;
maintainers = with maintainers; [ wkennington ];
nativeBuildInputs = [ pkgconfig ];
buildInputs = [ libevdev mtdev udev ]
++ optionals eventGUISupport [ cairo glib gtk3 ]
++ optionals documentationSupport [ doxygen graphviz ]
++ optionals testsSupport [ check valgrind ];
meta = {
description = "Handles input devices in Wayland compositors and provides a generic X.Org input driver";
homepage = http://www.freedesktop.org/wiki/Software/libinput;
license = licenses.mit;
platforms = platforms.unix;
maintainers = with maintainers; [ codyopel wkennington ];
};
}

View File

@ -6352,7 +6352,9 @@ let
inherit (gnome) gtkdoc;
};
libinput = callPackage ../development/libraries/libinput { };
libinput = callPackage ../development/libraries/libinput {
graphviz = graphviz-nox;
};
libiptcdata = callPackage ../development/libraries/libiptcdata { };