diff options
Diffstat (limited to 'libraries/libvirt/libvirt.SlackBuild')
-rw-r--r-- | libraries/libvirt/libvirt.SlackBuild | 110 |
1 files changed, 74 insertions, 36 deletions
diff --git a/libraries/libvirt/libvirt.SlackBuild b/libraries/libvirt/libvirt.SlackBuild index 84008caff4..1da38ef831 100644 --- a/libraries/libvirt/libvirt.SlackBuild +++ b/libraries/libvirt/libvirt.SlackBuild @@ -1,13 +1,19 @@ -#!/bin/sh +#!/bin/bash # Slackware build script for libvirt # Written by Michal Bialozor <bialyy@o2.pl> # Maintained by Robby Workman <rworkman@slackbuilds.org> +# 20220422 bkw: Modified by SlackBuilds.org, BUILD=2: +# - strip binaries. + +cd $(dirname $0) ; CWD=$(pwd) + PRGNAM=libvirt -VERSION=${VERSION:-4.5.0} -BUILD=${BUILD:-2} +VERSION=${VERSION:-9.1.0} +BUILD=${BUILD:-1} TAG=${TAG:-_SBo} +PKGTYPE=${PKGTYPE:-tgz} if [ -z "$ARCH" ]; then case "$( uname -m )" in @@ -17,7 +23,11 @@ if [ -z "$ARCH" ]; then esac fi -CWD=$(pwd) +if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then + echo "$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE" + exit 0 +fi + TMP=${TMP:-/tmp/SBo} PKG=$TMP/package-$PRGNAM OUTPUT=${OUTPUT:-/tmp} @@ -33,8 +43,16 @@ else LIBDIRSUFFIX="" fi +VIRTUSER=${VIRTUSER:-root} VIRTGROUP=${VIRTGROUP:-users} +# Some optional dependencies checks +audit="dis" ; if pkg-config --exists audit ; then audit="en" ; fi +bash_completion="" ; if pkg-config --exists bash-completion ; then + bash_completion="-Dbash_completion=enabled -Dbash_completion_dir=/usr/share/bash-completion/completions" +fi +libiscsi="dis" ; if pkg-config --exists libiscsi ; then libiscsi="en" ; fi + set -e rm -rf $PKG @@ -46,43 +64,58 @@ cd $PRGNAM-$VERSION chown -R root:root . find -L . \ \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ - -o -perm 511 \) -exec chmod 755 {} \; -o \ + -o -perm 511 \) -exec chmod 755 {} \+ -o \ \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \ - -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; + -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \+ # we have sysctld files in /etc/sysctl.d -sed -i "s|(prefix)/lib/sysctl|(sysconfdir)/sysctl|" src/Makefile.in +sed -i "s|prefix / 'lib' / 'sysctl.d'|sysconfdir / 'sysctl.d'|" src/remote/meson.build patch -p1 < $CWD/use-virtgroup-in-polkit-rules.diff sed -i -e "s,@VIRTGROUP@,$VIRTGROUP,g" src/remote/libvirtd.rules -CFLAGS="$SLKCFLAGS" \ -./configure \ - --prefix=/usr \ - --libdir=/usr/lib${LIBDIRSUFFIX} \ - --bindir=/usr/sbin \ - --sbindir=/usr/sbin \ - --sysconfdir=/etc \ - --localstatedir=/var \ - --mandir=/usr/man \ - --docdir=/usr/doc/$PRGNAM-$VERSION \ - --enable-static=no \ - --enable-shared=yes \ - --with-yajl \ - --with-qemu-group=$VIRTGROUP \ - --with-init-script=none - -make \ - HTML_DIR=/usr/doc/$PRGNAM-$VERSION \ - EXAMPLE_DIR=/usr/doc/$PRGNAM-$VERSION/examples -make \ - HTML_DIR=/usr/doc/$PRGNAM-$VERSION \ - EXAMPLE_DIR=/usr/doc/$PRGNAM-$VERSION/examples \ - install-strip DESTDIR=$PKG +# Since 5.10: "configure: error: Build directory must be different from source directory" +mkdir -p build +cd build + CFLAGS="$SLKCFLAGS" \ + CXXFLAGS="$SLKCFLAGS" \ + meson setup .. \ + --buildtype=release \ + --infodir=/usr/info \ + --libdir=/usr/lib${LIBDIRSUFFIX} \ + --localstatedir=/var \ + --mandir=/usr/man \ + --prefix=/usr \ + --sysconfdir=/etc \ + -Dqemu_group=$VIRTGROUP \ + -Dqemu_user=$VIRTUSER \ + $bash_completion \ + -Daudit=${audit}abled \ + -Dlibiscsi=${libiscsi}abled \ + -Dopenwsman=disabled \ + -Dapparmor=disabled \ + -Dselinux=disabled \ + -Dwireshark_dissector=disabled \ + -Ddriver_bhyve=disabled \ + -Ddriver_hyperv=disabled \ + -Ddriver_libxl=disabled \ + -Ddriver_vz=disabled \ + -Dsecdriver_apparmor=disabled \ + -Dsecdriver_selinux=disabled \ + -Dstorage_vstorage=disabled \ + -Ddtrace=disabled \ + -Dstrip=true \ + -Dinit_script=none + "${NINJA:=ninja}" + DESTDIR=$PKG $NINJA install +cd .. # we don't have augeas rm -fr $PKG/usr/share/augeas +# this tree is recreated when starting the daemon +rm -fR $PKG/var/run + # add an rc.libvirt to start/stop/restart the daemon install -D -m 0755 $CWD/rc.libvirt $PKG/etc/rc.d/rc.libvirt.new @@ -102,15 +135,20 @@ sed -i \ $PKG/etc/libvirt/qemu.conf # disable seccomp support or else VMs won't start with new libvirt/qemu combo -sed -i "s|^\#seccomp_sandbox = 1|seccomp_sandbox = 0|" \ - $PKG/etc/libvirt/qemu.conf +# 20220212 bkw: this file doesn't exist if qemu wasn't installed. and +# since qemu isn't in REQUIRES, it's optional, so the build shouldn't fail. +if [ -e $PKG/etc/libvirt/qemu.conf ]; then + sed -i "s|^\#seccomp_sandbox = 1|seccomp_sandbox = 0|" \ + $PKG/etc/libvirt/qemu.conf +fi -find $PKG/usr/man -type f -exec gzip -9 {} \; -for i in $( find $PKG/usr/man -type l ) ; do ln -s $( readlink $i ).gz $i.gz ; rm $i ; done +gzip -9 $PKG/usr/man/man*/* mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION +mv $PKG/usr/share/doc/$PRGNAM/* $PKG/usr/doc/$PRGNAM-$VERSION/ +rm -fR $PKG/usr/share/doc cp -a \ - AUTHORS ChangeLog COPYING* INSTALL README NEWS examples/polkit/* \ + *.rst COPYING* examples/polkit/* \ $PKG/usr/doc/$PRGNAM-$VERSION cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild @@ -129,4 +167,4 @@ for i in etc/libvirt etc/libvirt/nwfilter etc/libvirt/qemu/networks etc/logrotat done cd $PKG -/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz} +/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE |