nixpkgs/pkgs/development/libraries/libvirt/default.nix

99 lines
3.0 KiB
Nix
Raw Normal View History

{ stdenv, fetchurl, fetchpatch
, pkgconfig, makeWrapper
2017-03-25 13:58:26 +00:00
, libxml2, gnutls, devicemapper, perl, python2, attr
, iproute, iptables, readline, lvm2, utillinux, systemd, libpciaccess, gettext
2017-03-25 13:58:26 +00:00
, libtasn1, ebtables, libgcrypt, yajl, pmutils, libcap_ng, libapparmor
, dnsmasq, libnl, libpcap, libxslt, xhtml1, numad, numactl, perlPackages
2017-04-10 21:36:35 +00:00
, curl, libiconv, gmp, xen, zfs, parted
}:
2017-03-23 20:26:37 +00:00
with stdenv.lib;
2016-04-19 21:53:47 +00:00
# if you update, also bump pythonPackages.libvirt or it will break
stdenv.mkDerivation rec {
name = "libvirt-${version}";
version = "3.1.0";
src = fetchurl {
url = "http://libvirt.org/sources/${name}.tar.xz";
sha256 = "1a9j6yqfy7i5yv414wk6nv26a5bpfyyg0rpcps6ybi6a1yd04ybq";
};
patches = [ ./build-on-bsd.patch ];
nativeBuildInputs = [ makeWrapper pkgconfig ];
buildInputs = [
libxml2 gnutls perl python2 readline gettext libtasn1 libgcrypt yajl
2017-04-11 14:05:07 +00:00
attr libxslt xhtml1 perlPackages.XMLXPath curl libpcap parted
2017-03-23 20:26:37 +00:00
] ++ optionals stdenv.isLinux [
libpciaccess devicemapper lvm2 utillinux systemd libnl numad zfs
libapparmor libcap_ng numactl xen
2017-03-23 20:26:37 +00:00
] ++ optionals stdenv.isDarwin [
libiconv gmp
];
2017-03-23 20:26:37 +00:00
preConfigure = optionalString stdenv.isLinux ''
2016-08-22 22:13:49 +00:00
PATH=${stdenv.lib.makeBinPath [ iproute iptables ebtables lvm2 systemd ]}:$PATH
2016-07-01 18:12:33 +00:00
substituteInPlace configure \
--replace 'as_dummy="/bin:/usr/bin:/usr/sbin"' 'as_dummy="${numad}/bin"'
'' + ''
PATH=${dnsmasq}/bin:$PATH
patchShebangs . # fixes /usr/bin/python references
'';
configureFlags = [
"--localstatedir=/var"
"--sysconfdir=/var/lib"
"--with-libpcap"
"--with-vmware"
"--with-vbox"
"--with-test"
"--with-esx"
"--with-remote"
2017-04-10 21:36:35 +00:00
"--with-storage-disk"
2017-03-23 20:26:37 +00:00
] ++ optionals stdenv.isLinux [
2017-03-25 13:58:26 +00:00
"--with-attr"
"--with-apparmor"
"--with-secdriver-apparmor"
2015-12-15 18:55:39 +00:00
"--with-numad"
"--with-macvtap"
"--with-virtualport"
"--with-init-script=systemd+redhat"
2016-05-23 02:03:41 +00:00
"--with-storage-zfs"
2017-03-23 20:26:37 +00:00
] ++ optionals stdenv.isDarwin [
"--with-init-script=none"
];
installFlags = [
"localstatedir=$(TMPDIR)/var"
"sysconfdir=$(out)/var/lib"
];
postInstall = ''
sed -i 's/ON_SHUTDOWN=suspend/ON_SHUTDOWN=''${ON_SHUTDOWN:-suspend}/' $out/libexec/libvirt-guests.sh
substituteInPlace $out/libexec/libvirt-guests.sh \
--replace "$out/bin" "${gettext}/bin" \
--replace "lock/subsys" "lock"
rm $out/lib/systemd/system/{virtlockd,virtlogd}.*
2017-03-23 20:26:37 +00:00
'' + optionalString stdenv.isLinux ''
wrapProgram $out/sbin/libvirtd \
2017-03-23 20:26:37 +00:00
--prefix PATH : ${makeBinPath [ iptables iproute pmutils numad numactl ]}
'';
enableParallelBuilding = true;
NIX_CFLAGS_COMPILE = "-fno-stack-protector";
2017-03-23 20:26:37 +00:00
meta = {
homepage = http://libvirt.org/;
repositories.git = git://libvirt.org/libvirt.git;
description = ''
A toolkit to interact with the virtualization capabilities of recent
versions of Linux (and other OSes)
'';
license = licenses.lgpl2Plus;
platforms = platforms.unix;
2016-03-19 15:33:49 +00:00
maintainers = with maintainers; [ fpletz ];
};
}