# Copyright 1999-2015 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Id$ EAPI="5" PYTHON_COMPAT=( python{2_7,3_3,3_4} ) inherit python-r1 eutils MY_P="${P//_/-}" MY_RELEASEDATE="20150202" DESCRIPTION="SELinux policy generation library" HOMEPAGE="https://github.com/SELinuxProject/selinux/wiki" if [[ ${PV} == 9999 ]] ; then inherit git-r3 EGIT_REPO_URI="https://github.com/SELinuxProject/selinux.git" S="${WORKDIR}/${MY_P}/${PN}" else SRC_URI="https://raw.githubusercontent.com/wiki/SELinuxProject/selinux/files/releases/20150202/${MY_P}.tar.gz" KEYWORDS="~amd64 ~x86" S="${WORKDIR}/${MY_P}" fi LICENSE="GPL-2" SLOT="0" IUSE="" DEPEND=">=sys-libs/libselinux-2.0[python] app-admin/setools[python(+)] ${PYTHON_DEPS}" RDEPEND="${DEPEND}" src_prepare() { if [[ ${PV} != 9999 ]] ; then # If needed for live ebuilds please use /etc/portage/patches epatch "${FILESDIR}/0030-default-path-for-tests-also-needed-bug-467264.patch" fi epatch_user python_copy_sources } src_compile() { : } src_test() { if has_version sec-policy/selinux-base-policy; then invoke_sepolgen_test() { emake test } python_foreach_impl invoke_sepolgen_test else ewarn "Sepolgen requires sec-policy/selinux-base-policy to run tests." fi } src_install() { installation() { emake DESTDIR="${D}" PYTHONLIBDIR="$(python_get_sitedir)" install python_optimize } python_foreach_impl installation # Create sepolgen.conf with different devel location definition if [[ -f /etc/selinux/config ]]; then local selinuxtype=$(awk -F'=' '/^SELINUXTYPE/ {print $2}' /etc/selinux/config); mkdir -p "${D}"/etc/selinux || die "Failed to create selinux directory"; echo "SELINUX_DEVEL_PATH=/usr/share/selinux/${selinuxtype}/include:/usr/share/selinux/${selinuxtype}" > "${D}"/etc/selinux/sepolgen.conf; else local selinuxtype="${POLICY_TYPES%% *}"; if [[ -n "${selinuxtype}" ]]; then echo "SELINUX_DEVEL_PATH=/usr/share/selinux/${selinuxtype}/include:/usr/share/selinux/${selinuxtype}" > "${D}"/etc/selinux/sepolgen.conf; else echo "SELINUX_DEVEL_PATH=/usr/share/selinux/strict/include:/usr/share/selinux/strict" > "${D}"/etc/selinux/sepolgen.conf; fi fi }