commit:     6000a198e1442ac9fa7c24fe0da85f6d855d3abb
Author:     Jason Zaman <perfinion <AT> gentoo <DOT> org>
AuthorDate: Sun Mar  9 19:37:36 2025 +0000
Commit:     Jason Zaman <perfinion <AT> gentoo <DOT> org>
CommitDate: Sun Mar  9 21:57:06 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6000a198

sys-apps/selinux-python: bump to 3.8.1

Signed-off-by: Jason Zaman <perfinion <AT> gentoo.org>

 sys-apps/selinux-python/Manifest                   |   1 +
 .../selinux-python/selinux-python-3.8.1.ebuild     | 117 +++++++++++++++++++++
 2 files changed, 118 insertions(+)

diff --git a/sys-apps/selinux-python/Manifest b/sys-apps/selinux-python/Manifest
index e99a979b61e0..d16ded54b0d8 100644
--- a/sys-apps/selinux-python/Manifest
+++ b/sys-apps/selinux-python/Manifest
@@ -1,2 +1,3 @@
 DIST selinux-python-3.7.tar.gz 3652377 BLAKE2B 
59fd7cab0034c175f42f6120ba665701945adcbd4e8af97a0dc2a1c79688a596b199528886ceea079a3f7a969258611fb660449d313d9e893de381293e786381
 SHA512 
036bc1f0e64cbbaade592dc7899a92765a0bac426140d7d3960f73bad6eb5f95d79d91e0f0e1604f88a991ebf59c4c90ccaaa4158f5dc4d3275ca2aed1673b09
+DIST selinux-python-3.8.1.tar.gz 3652823 BLAKE2B 
dde6081f55d646a6993083a000524b4ce834718f7cd555c8be88574f227f3d8ed24f390dc4568f3f66c1f3643a606779b6350ad28dfbfe2a1bd9d5a6798c37e0
 SHA512 
bad791411cff373cf749302d44205495a9d100ca6140ea895cb87a85f5d0b0cfaaf4b7418fca661fb3233d14951755d1c2d85961c731243c92622fdfb343734a
 DIST selinux-python-3.8.tar.gz 3652643 BLAKE2B 
1626fe75466be418394fdd896c250044ada8ebf4bdfe7da10c7d038cbce7882037f9e8c87bb0b569deeff51323c68652e6ae8ef9525e13d93b7f30b06b960858
 SHA512 
d5f6fcf64f2780be320b8a8dabe6370b5403ca9119db61fea8b1be798a84a174738a564c1c8a3c6bfec922becaf3da02aeb2a63d065627cecab4ff48126cfac9

diff --git a/sys-apps/selinux-python/selinux-python-3.8.1.ebuild 
b/sys-apps/selinux-python/selinux-python-3.8.1.ebuild
new file mode 100644
index 000000000000..e9776921c2c0
--- /dev/null
+++ b/sys-apps/selinux-python/selinux-python-3.8.1.ebuild
@@ -0,0 +1,117 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI="8"
+PYTHON_COMPAT=( python3_{10..13} )
+PYTHON_REQ_USE="xml(+)"
+
+inherit python-r1 toolchain-funcs
+
+MY_PV="${PV//_/-}"
+MY_P="${PN}-${MY_PV}"
+
+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/${MY_PV}/${MY_P}.tar.gz";
+       KEYWORDS="~amd64 ~arm ~arm64 ~x86"
+       S="${WORKDIR}/${MY_P}"
+fi
+
+LICENSE="GPL-2"
+SLOT="0"
+IUSE="test"
+RESTRICT="!test? ( test )"
+REQUIRED_USE="${PYTHON_REQUIRED_USE}"
+
+RDEPEND=">=sys-libs/libselinux-${PV}:=[python]
+       >=sys-libs/libsemanage-${PV}:=[python(+)]
+       >=sys-libs/libsepol-${PV}:=[static-libs(+)]
+       >=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
+       mkdir -p "${D}"/etc/selinux || die "Failed to create selinux directory";
+       if [[ -f /etc/selinux/config ]];
+       then
+               local selinuxtype=$(awk -F'=' '/^SELINUXTYPE/ {print $2}' 
/etc/selinux/config);
+               echo 
"SELINUX_DEVEL_PATH=/usr/share/selinux/${selinuxtype}/include:/usr/share/selinux/${selinuxtype}"
 \
+                       > "${D}"/etc/selinux/sepolgen.conf || die "Failed to 
generate sepolgen"
+       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 || die 
"Failed to generate sepolgen"
+               else
+                       echo 
"SELINUX_DEVEL_PATH=/usr/share/selinux/strict/include:/usr/share/selinux/strict"
 \
+                               > "${D}"/etc/selinux/sepolgen.conf || die 
"Failed to generate sepolgen"
+               fi
+       fi
+}

Reply via email to