# Copyright 1999-2021 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI="7" inherit linux-info systemd toolchain-funcs udev DESCRIPTION="Device mapper target autoconfig" HOMEPAGE="http://christophe.varoqui.free.fr/" SRC_URI="https://github.com/opensvc/${PN}/archive/refs/tags/${PV}.tar.gz -> ${P}.tar.gz" LICENSE="GPL-2" SLOT="0" KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~ia64 ~ppc ~ppc64 ~x86" IUSE="systemd rbd test" RESTRICT="!test? ( test )" RDEPEND=" dev-libs/json-c:= dev-libs/libaio dev-libs/userspace-rcu:= >=sys-fs/lvm2-2.02.45 >=virtual/libudev-232-r3 sys-libs/readline:0= rbd? ( sys-cluster/ceph ) systemd? ( sys-apps/systemd ) " DEPEND="${RDEPEND} test? ( dev-util/cmocka )" BDEPEND="virtual/pkgconfig" CONFIG_CHECK="~DM_MULTIPATH" PATCHES=( "${FILESDIR}"/${PN}-0.8.7-respect-flags.patch "${FILESDIR}"/${PN}-0.8.6-no-compress-man-pages.patch ) src_prepare() { default # The upstream lacks any way to configure the build at present # and ceph is a huge dependency, so we're using sed to make it # optional until the upstream has a proper configure system if ! use rbd ; then sed \ -e "s/libcheckrbd.so/# libcheckrbd.so/" \ -e "s/-lrados//" \ -i libmultipath/checkers/Makefile \ || die fi } src_compile() { tc-export CC # LIBDM_API_FLUSH involves grepping files in /usr/include, # so force the test to go the way we want #411337. emake \ LIB="${EPREFIX}/$(get_libdir)" \ LIBDM_API_FLUSH=1 \ PKGCONFIG="$(tc-getPKG_CONFIG)" } src_install() { dodir /sbin /usr/share/man/man{3,5,8} emake \ DESTDIR="${D}" \ LIB="${EPREFIX}/$(get_libdir)" \ RUN=run \ unitdir="$(systemd_get_systemunitdir)" \ libudevdir='${prefix}'/"$(get_udevdir)" \ pkgconfdir='${prefix}'/usr/'${LIB}'/pkgconfig \ install newinitd "${FILESDIR}"/multipathd-r1.rc multipathd newinitd "${FILESDIR}"/multipath.rc multipath einstalldocs find "${ED}" -type f -name "*.la" -delete || die } pkg_postinst() { if [[ -z ${REPLACING_VERSIONS} ]] ; then elog "If you need multipath on your system, you must" elog "add 'multipath' into your boot runlevel!" fi }