commit:     5855eccb1934700fe374623f4fee1b0801a6d3f5
Author:     Jonathan Davies <jpds <AT> protonmail <DOT> com>
AuthorDate: Sun Oct 24 11:53:59 2021 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Oct 31 02:50:25 2021 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5855eccb

sys-apps/selinux-python: Version updated to 3.3, with changes:

* Dropped optional-networkx.patch - applied upstream.

Signed-off-by: Jonathan Davies <jpds <AT> protonmail.com>
Signed-off-by: Sam James <sam <AT> gentoo.org>

 sys-apps/selinux-python/Manifest                  |   1 +
 sys-apps/selinux-python/selinux-python-3.3.ebuild | 111 ++++++++++++++++++++++
 2 files changed, 112 insertions(+)

diff --git a/sys-apps/selinux-python/Manifest b/sys-apps/selinux-python/Manifest
index ef17a3d066a..ab68bfe1578 100644
--- a/sys-apps/selinux-python/Manifest
+++ b/sys-apps/selinux-python/Manifest
@@ -1,2 +1,3 @@
 DIST selinux-python-3.1.tar.gz 2100549 BLAKE2B 
c5d207bad60c379259e3bfc8f029f76d4572818cdd41a263498ed4434a70eaf7ff51af7772cfb27de0e9e4af03bcf9906ab0f6a59e88de10e81cbe0e8c5928b8
 SHA512 
5dd98f77ae8ea8bac6a89ec7def76e12496b9a9f8c9612c4cc1dac7a8e8c60380a00c857426bfefbcb4273706addd2594e9b467f69408ef284f082a09d45bd49
 DIST selinux-python-3.2.tar.gz 2101106 BLAKE2B 
b4b185a7468de68eb2146011a9bc82ffb7db9878517833c1e8dfa23279aec3dfbf46a27b70b17c1e317a2c939bcf6d1748638fd4a078325b853de34ae3c51a6f
 SHA512 
2c3483e27c4ad6942e23e39897e0eccf61b95d685ace62315678cb49739d300d4ca4a7a51fa7a9aacaa98737446a70923855d15827eb6275ffd6999be0b2a755
+DIST selinux-python-3.3.tar.gz 2101584 BLAKE2B 
603aafbf316b744098bd34c79bf384d55624c086fd75147675a4a0715df3d61710a99d490f30b78d59a2c2a85fcc4db91772c24644a963b31e1a0d305c4bc83e
 SHA512 
a69948a8b139a309f18632440e4204f49832a94b8b6be50e162d3dacb16698effeb1a77c44462e8cc7dc3dd600b887b9ab2fef618c31d3e0fe0de216a6aaebe3

diff --git a/sys-apps/selinux-python/selinux-python-3.3.ebuild 
b/sys-apps/selinux-python/selinux-python-3.3.ebuild
new file mode 100644
index 00000000000..8e1f90984a8
--- /dev/null
+++ b/sys-apps/selinux-python/selinux-python-3.3.ebuild
@@ -0,0 +1,111 @@
+# Copyright 1999-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+PYTHON_COMPAT=( python3_{7..9} )
+PYTHON_REQ_USE="xml"
+
+inherit python-r1 toolchain-funcs
+
+IUSE="test"
+RESTRICT="!test? ( test )"
+REQUIRED_USE="${PYTHON_REQUIRED_USE}"
+
+DESCRIPTION="SELinux core utilities"
+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}/${P}/${PN#selinux-}"
+else
+       
SRC_URI="https://github.com/SELinuxProject/selinux/releases/download/${PV}/${P}.tar.gz";
+       KEYWORDS="~amd64 ~arm ~arm64 ~mips ~x86"
+fi
+
+LICENSE="GPL-2"
+SLOT="0"
+
+RDEPEND=">=sys-libs/libselinux-${PV}:=[python]
+       >=sys-libs/libsemanage-${PV}:=[python(+)]
+       >=sys-libs/libsepol-${PV}:=
+       >=app-admin/setools-4.2.0[${PYTHON_USEDEP}]
+       >=sys-process/audit-1.5.1[python,${PYTHON_USEDEP}]
+       ${PYTHON_DEPS}"
+DEPEND="${RDEPEND}"
+BDEPEND="
+       test? (
+               ${RDEPEND}
+               >=sys-apps/secilc-${PV}
+       )"
+
+src_prepare() {
+       default
+       sed -i 's/-Werror//g' "${S}"/*/Makefile || die "Failed to remove Werror"
+
+       python_copy_sources
+}
+
+src_compile() {
+       building() {
+               emake -C "${BUILD_DIR}" \
+                       CC="$(tc-getCC)" \
+                       LIBDIR="\$(PREFIX)/$(get_libdir)"
+       }
+       python_foreach_impl building
+}
+
+src_test() {
+       testing() {
+               # The different subprojects have some interproject dependencies:
+               # - audit2allow depens on sepolgen
+               # - chcat depends on semanage
+               # and maybe others.
+               # Add all the modules of the individual subprojects to the
+               # PYTHONPATH, so they get actually found and used. In
+               # particular, already installed versions on the system are not
+               # used.
+               for dir in audit2allow chcat semanage sepolgen/src sepolicy ; do
+                       PYTHONPATH="${BUILD_DIR}/${dir}:${PYTHONPATH}"
+               done
+               PYTHONPATH=${PYTHONPATH} \
+                       emake -C "${BUILD_DIR}" \
+                               test
+       }
+       python_foreach_impl testing
+}
+
+src_install() {
+       installation() {
+               emake -C "${BUILD_DIR}" \
+                       DESTDIR="${D}" \
+                       LIBDIR="\$(PREFIX)/$(get_libdir)" \
+                       install
+               python_optimize
+       }
+       python_foreach_impl installation
+
+       # Set version-specific scripts
+       for pyscript in audit2allow sepolgen-ifgen sepolicy chcat; do
+               python_replicate_script "${ED}/usr/bin/${pyscript}"
+       done
+       for pyscript in semanage; do
+               python_replicate_script "${ED}/usr/sbin/${pyscript}"
+       done
+
+       # 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
+}

Reply via email to