gentoo-ebuilds/sys-apps/minijail/minijail-2025.07.02.ebuild
Patrick McLean 2dd5290ede
sys-apps/minijail: add 2025.07.02
Signed-off-by: Patrick McLean <chutzpah@gentoo.org>
2025-08-06 12:10:07 -07:00

87 lines
1.9 KiB
Bash

# Copyright 1999-2025 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
inherit linux-info toolchain-funcs
DESCRIPTION="helper binary and library for sandboxing & restricting privs of service"
HOMEPAGE="
https://android.googlesource.com/platform/external/minijail
https://github.com/google/minijail
"
# Use GitHub mirror as Gitiles doesn't generate stable tarballs.
SRC_URI="https://github.com/google/${PN}/archive/linux-v${PV}.tar.gz -> ${P}.tar.gz"
S="${WORKDIR}/${PN}-linux-v${PV}"
LICENSE="BSD"
SLOT="0"
KEYWORDS="~amd64 ~riscv ~x86"
IUSE="+seccomp test"
RESTRICT="!test? ( test )"
RDEPEND="
sys-libs/libcap-ng:=
"
DEPEND="
${RDEPEND}
test? (
>=dev-cpp/gtest-1.8.0:=
)
"
BDEPEND="
test? (
virtual/pkgconfig
)
"
PATCHES=(
"${FILESDIR}/${PN}-2025.07.02-makefile.patch"
"${FILESDIR}/${PN}-2025.07.02-no-werror.patch"
)
pkg_pretend() {
local CONFIG_CHECK="~NAMESPACES ~UTS_NS ~IPC_NS ~USER_NS ~PID_NS ~NET_NS
~SECCOMP ~SECCOMP_FILTER ~CGROUPS"
check_extra_config
}
src_configure() {
export LIBDIR="/usr/$(get_libdir)"
export USE_seccomp="$(usex seccomp)"
export USE_SYSTEM_GTEST=yes
if use test; then
export GTEST_CXXFLAGS="$($(tc-getPKG_CONFIG) --cflags gtest_main)"
export GTEST_LIBS="$($(tc-getPKG_CONFIG) --libs gtest_main)"
else
export GTEST_CXXFLAGS='' GTEST_LIBS=''
fi
export VERBOSE=1
}
src_compile() {
tc-env_build emake all parse_seccomp_policy
}
src_test() {
GTEST_FILTER="-NamespaceTest.test_tmpfs_userns:NamespaceTest.test_namespaces" \
tc-env_build emake tests
}
src_install() {
dosbin minijail0
dolib.so libminijail{,preload}.so
dobin parse_seccomp_policy
doman minijail0.[15]
dodoc README.md
local include_dir="/usr/include"
"${S}"/platform2_preinstall.sh "${PV}" "${include_dir}"
insinto "/usr/$(get_libdir)/pkgconfig"
doins libminijail.pc
insinto "${include_dir}"
doins libminijail.h scoped_minijail.h
}