summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrey Utkin <andrey_utkin@gentoo.org>2018-07-28 01:09:12 +0100
committerAndrey Utkin <andrey_utkin@gentoo.org>2018-07-29 02:40:49 +0100
commit87056724896f44e4d1843e0e8d17806bdecf11a5 (patch)
treeafe2e47470093de87e4bdadd863828aac650a755 /dev-util/tup/tup-9999.ebuild
parentkde-apps/konqueror: amd64 stable wrt bug #661810 (diff)
downloadgentoo-87056724896f44e4d1843e0e8d17806bdecf11a5.tar.gz
gentoo-87056724896f44e4d1843e0e8d17806bdecf11a5.tar.bz2
gentoo-87056724896f44e4d1843e0e8d17806bdecf11a5.zip
dev-util/tup: add new package
Based on work by Cody P Schafer <dev@codyps.com> (jmesmon overlay). Package-Manager: Portage-2.3.40, Repoman-2.3.9
Diffstat (limited to 'dev-util/tup/tup-9999.ebuild')
-rw-r--r--dev-util/tup/tup-9999.ebuild98
1 files changed, 98 insertions, 0 deletions
diff --git a/dev-util/tup/tup-9999.ebuild b/dev-util/tup/tup-9999.ebuild
new file mode 100644
index 000000000000..104dd83a9dbd
--- /dev/null
+++ b/dev-util/tup/tup-9999.ebuild
@@ -0,0 +1,98 @@
+# Copyright 1999-2018 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+inherit toolchain-funcs
+
+DESCRIPTION="A file-based build system"
+HOMEPAGE="http://gittup.org/tup"
+# Tup itself is GPLv2, but it bundles differently licensed software:
+# - lua: MIT
+# - sqlite (unused in this ebuild): public domain
+# - inih: 3-clause BSD
+# - red-black tree implementation: 2-clause BSD
+# - queue implementation: 3-clause BSD
+LICENSE="GPL-2 MIT public-domain BSD BSD-2"
+SLOT="0"
+
+if [[ "${PV}" == 9999 ]]; then
+ EGIT_REPO_URI="https://github.com/gittup/tup.git"
+ inherit git-r3
+else
+ SRC_URI="https://github.com/gittup/tup/archive/v${PV}.tar.gz -> ${P}.tar.gz"
+ KEYWORDS="~amd64"
+fi
+
+DEPEND="
+ dev-db/sqlite:=
+ sys-fs/fuse:=
+"
+RDEPEND="${DEPEND}"
+
+src_prepare() {
+ # Use our toolchain
+ sed -i Tuprules.tup \
+ -e "s:CC = gcc:CC = $(tc-getCC) ${CFLAGS} ${LDFLAGS}:" \
+ -e "s:ar crs:$(tc-getAR) crs:"
+
+ if [[ ${PV} != 9999 ]]; then
+ # Avoid invoking `git` to find version, use ours
+ sed -i src/tup/link.sh \
+ -e 's;`git describe`;v'"${PV};"
+ fi
+
+ default
+}
+
+src_configure () {
+ echo "CONFIG_TUP_USE_SYSTEM_SQLITE=y" >> tup.config
+}
+
+src_compile() {
+ # Disabling namespacing because it leads to accessing /proc/<pid>/setgroups
+ # which violates sandboxing.
+ export TUP_NO_NAMESPACING=1
+ ./bootstrap-nofuse.sh || die
+ unset TUP_NO_NAMESPACING
+}
+
+src_install() {
+ dobin tup
+ dolib.a libtup_client.a
+ doheader tup_client.h
+ doman tup.1
+}
+
+src_test() {
+ # tup uses fuse when tracking dependencies.
+ addwrite /dev/fuse
+
+ # Disabling namespacing because it leads to accessing /proc/<pid>/setgroups
+ # which violates sandboxing.
+ export TUP_NO_NAMESPACING=1
+
+ # Skip tests which require namespacing or root privileges.
+ SKIPPED_TESTS=(
+ t4062-full-deps.sh
+ t4063-full-deps2.sh
+ t4064-full-deps3.sh
+ t4065-full-deps-proc.sh
+ t4067-full-deps5.sh
+ t4069-gcc-coverage.sh
+ t4072-proc-self.sh
+ t4074-getpwd.sh
+ t4131-proc-self-exe.sh
+ t4132-proc-meminfo.sh
+ t4171-dev-null.sh
+ t5083-symlink-fullpath.sh
+ t5084-symlink-fullpath2.sh
+ t7048-full-deps.sh
+ )
+ pushd test || die
+ rm ${SKIPPED_TESTS[@]} || die
+ ./test.sh || die
+ popd || die
+
+ unset TUP_NO_NAMESPACING
+}