Gentoo Archives: gentoo-commits

From: Zac Medico <zmedico@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: app-emulation/rkt/
Date: Sun, 02 Oct 2016 00:44:55
Message-Id: 1475369032.df997b354495a0c04ea7a5d3aefe7140825445ea.zmedico@gentoo
1 commit: df997b354495a0c04ea7a5d3aefe7140825445ea
2 Author: Zac Medico <zmedico <AT> gentoo <DOT> org>
3 AuthorDate: Sun Oct 2 00:43:52 2016 +0000
4 Commit: Zac Medico <zmedico <AT> gentoo <DOT> org>
5 CommitDate: Sun Oct 2 00:43:52 2016 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=df997b35
7
8 app-emulation/rkt: version bump to 1.16.0
9
10 Package-Manager: portage-2.3.1
11
12 app-emulation/rkt/Manifest | 1 +
13 app-emulation/rkt/rkt-1.16.0.ebuild | 239 ++++++++++++++++++++++++++++++++++++
14 2 files changed, 240 insertions(+)
15
16 diff --git a/app-emulation/rkt/Manifest b/app-emulation/rkt/Manifest
17 index 16aa40b..c92ac18 100644
18 --- a/app-emulation/rkt/Manifest
19 +++ b/app-emulation/rkt/Manifest
20 @@ -3,5 +3,6 @@ DIST linux-4.3.1.tar.xz 86900452 SHA256 11faaff6e7546038b868f524cdf42a5a1b67be9f
21 DIST qemu-2.6.1.tar.bz2 25762855 SHA256 4942fd1b6ee31f2f55ffc2201dd7397e6b9c55a2ef332e6d660c730d268e08d1 SHA512 adb55d0774618c9cd02d376222814f2047977bfbca73248841275084ae537db583db4ac6cfa5cc65c3182941d5f4b40f2f7f4661b2cd93cbb3796e2f325bc919 WHIRLPOOL 1b9c0de78fcf874fd307ce2ee49448e96140fae0ea5739af28947bf8f241e768b47abe3edd2d798b826d99cfd4ca143cf71192d254b54ab47515ac59327fc172
22 DIST rkt-1.14.0.tar.gz 2947502 SHA256 2458783023c561358c59600accb58ccfe335535931a58da988d70893a1c5a5e7 SHA512 4e082f0293047d133b031b6fd95e34fc86b7b2ca133ea56709cded5cd0c454e56bb5dd7209bc7add56812142495430c457d9094a8cda1c0079085822ff6e1c94 WHIRLPOOL 09837fc509cce2609bd87ae1185ce6c1e85e13888ab8106aab1725e8e3232486330e4152db8deb77dbc2c419d176a8f1c6df6d44d9a2808aefd62e58082a0353
23 DIST rkt-1.15.0.tar.gz 3018468 SHA256 3efd0dc96c8783d5b378862c7239f733863a181bb3148f3b2e8e10023df06e01 SHA512 4f35eee5f689c8a36760c784d079751cfd0224c20c60f915ab1a550040739ec9290ba9e481e1679f67044400f8d3a60588b6d6d6cdfbbc1f3093c7010d35d290 WHIRLPOOL a07cbd102280c911ba79748931f841d2d5e28407225f2b1d48604b1d0e1c3d81c6488c40e2ef4ef571b628f1766f9aa1e5208138ca963c06e7b3b9226f5b6b6c
24 +DIST rkt-1.16.0.tar.gz 3028683 SHA256 8c7bb07217b68e153d54e45646072fd267ee1ee88a410887f2d8f75eb4752e89 SHA512 b270c8340ca5a22c48209f9d8fa6c55e8cd1b8e238117c4e3a9e5d4fff04bde194e53d10112dd429f5f1c36e0395ca42ae6bd12fd5ebff68a50d3546a1a8d31d WHIRLPOOL d532cfac6347d675b5cbf96e9c38d4cdbb4f4fbd493474567755ff3560c31b8edc59c2cf83f51953ac56c81f7f1af84c625cf1c7f571a48275b6df3dd8f171f3
25 DIST rkt-pxe-1151.0.0.img 243335216 SHA256 6f08697bea372af916a150f9846110e8855305653e5582b2c2ea04f14253e5c8 SHA512 fe7c4ec8cb4d11ba704b9f78c43557a374fda70dbfd7c3f4f9e768cf5ae365aab7a1fee8d51e19bbad6809ad4cdfe4eed60e5cdb6babd869a3a91b503b7256e8 WHIRLPOOL 92f8a65a9c50c11fa9c56acee53dd5623dd186664f44c6517bac4ee5be6a9dd2a9141ef522d978cc5b282c6638e17bf7b3559d68d6ea6c0752821799c0c88a5c
26 DIST systemd-231.tar.gz 4381464 SHA256 899733ad6c157cedbb89aec4efe3bc824dcfd65a1d6f6bebc7b043f7924e39b4 SHA512 199fa33a0494d1d15f7fe3c796fe14913ad386766571d4d3fbb1cb1c446e04f6d06a965213be4c594a7183e810fc2fd4804fe14f64f21b0a1278b717889811c6 WHIRLPOOL 7779291e9fb9873cb1773b8583cf6d4b7dec837363ea89c4a73c1e397a76752b66f8b57d8fc4d9cef768cc1855b5e325ad88a8a69eb5380aa924e0a6dead41b1
27
28 diff --git a/app-emulation/rkt/rkt-1.16.0.ebuild b/app-emulation/rkt/rkt-1.16.0.ebuild
29 new file mode 100644
30 index 00000000..62861b0
31 --- /dev/null
32 +++ b/app-emulation/rkt/rkt-1.16.0.ebuild
33 @@ -0,0 +1,239 @@
34 +# Copyright 1999-2016 Gentoo Foundation
35 +# Distributed under the terms of the GNU General Public License v2
36 +# $Id$
37 +
38 +EAPI=6
39 +
40 +inherit bash-completion-r1 autotools flag-o-matic systemd toolchain-funcs user
41 +
42 +KEYWORDS="~amd64"
43 +
44 +PXE_VERSION="1151.0.0"
45 +PXE_SYSTEMD_VERSION="v231"
46 +KVM_LINUX_VERSION="4.3.1"
47 +KVMTOOL_VERSION="d62653e177597251c24494a6dda60acd6d846671"
48 +QEMU_VERSION="v2.6.1"
49 +PXE_URI="http://alpha.release.core-os.net/amd64-usr/${PXE_VERSION}/coreos_production_pxe_image.cpio.gz"
50 +PXE_FILE="${PN}-pxe-${PXE_VERSION}.img"
51 +
52 +SRC_URI_KVM="mirror://kernel/linux/kernel/v4.x/linux-${KVM_LINUX_VERSION}.tar.xz
53 + ${PXE_URI} -> ${PXE_FILE}
54 +"
55 +
56 +SRC_URI="https://github.com/coreos/${PN}/archive/v${PV}.tar.gz -> ${P}.tar.gz
57 +rkt_stage1_coreos? ( $PXE_URI -> $PXE_FILE )
58 +rkt_stage1_kvm_lkvm? (
59 + https://kernel.googlesource.com/pub/scm/linux/kernel/git/will/kvmtool/+archive/${KVMTOOL_VERSION}.tar.gz -> kvmtool-${KVMTOOL_VERSION}.tar.gz
60 + ${SRC_URI_KVM}
61 +)
62 +rkt_stage1_kvm_qemu? (
63 + http://wiki.qemu-project.org/download/qemu-${QEMU_VERSION#v}.tar.bz2
64 + ${SRC_URI_KVM}
65 +)
66 +rkt_stage1_src? ( https://github.com/systemd/systemd/archive/${PXE_SYSTEMD_VERSION}.tar.gz -> systemd-${PXE_SYSTEMD_VERSION#v}.tar.gz )"
67 +
68 +DESCRIPTION="rkt is an App Container runtime for Linux"
69 +HOMEPAGE="https://github.com/coreos/rkt"
70 +
71 +LICENSE="Apache-2.0"
72 +SLOT="0"
73 +# The rkt_stage1_kvm flag has been replaced by the rkt_stage1_kvm_lkvm and rkt_stage1_kvm_qemu flags
74 +IUSE="doc examples +rkt_stage1_coreos +rkt_stage1_fly rkt_stage1_host rkt_stage1_kvm rkt_stage1_kvm_lkvm rkt_stage1_kvm_qemu rkt_stage1_src +actool systemd"
75 +REQUIRED_USE="|| ( rkt_stage1_coreos rkt_stage1_fly rkt_stage1_host rkt_stage1_kvm_lkvm rkt_stage1_kvm_qemu rkt_stage1_src ) rkt_stage1_host? ( systemd ) !rkt_stage1_kvm"
76 +
77 +DEPEND=">=dev-lang/go-1.5
78 + app-arch/cpio
79 + app-crypt/trousers
80 + sys-fs/squashfs-tools
81 + dev-perl/Capture-Tiny
82 + rkt_stage1_src? ( >=sys-apps/util-linux-2.27 )
83 + rkt_stage1_kvm_qemu? (
84 + sys-libs/libcap[static-libs(+)]
85 + >=x11-libs/pixman-0.28.0[static-libs(+)]
86 + )"
87 +
88 +RDEPEND="!app-emulation/rocket
89 + rkt_stage1_host? ( systemd? (
90 + >=sys-apps/systemd-222
91 + app-shells/bash:0
92 + ) )"
93 +
94 +BUILDDIR="build-${P}"
95 +STAGE1_DEFAULT_LOCATION="/usr/share/rkt/stage1.aci"
96 +
97 +pkg_setup() {
98 + enewgroup rkt-admin
99 + enewgroup rkt
100 +}
101 +
102 +src_unpack() {
103 + local x
104 + for x in ${A}; do
105 + case ${x} in
106 + *.img|linux-*) continue ;;
107 + kvmtool-*)
108 + mkdir kvmtool || die
109 + pushd kvmtool >/dev/null || die
110 + unpack ${x}
111 + popd >/dev/null || die
112 + ;;
113 + *)
114 + unpack ${x}
115 + esac
116 + done
117 +}
118 +
119 +src_prepare() {
120 + eapply_user
121 +
122 + sed -e 's|^RKT_REQ_PROG(\[GIT\],.*|#\0|' -i configure.ac || die
123 +
124 + # disable git fetch of systemd
125 + sed -e 's~^include makelib/git.mk$~'\
126 +'ifneq ($(wildcard $(RKT_STAGE1_SYSTEMD_SRC)),)\n\n'\
127 +'get_systemd_sources: | $(UFS_SYSTEMDDIR)\n'\
128 +'\tmv "$(RKT_STAGE1_SYSTEMD_SRC)" "$(UFS_SYSTEMD_SRCDIR)"\n\n'\
129 +'$(UFS_SYSTEMD_CONFIGURE): get_systemd_sources\n\n'\
130 +'else ifneq ($(wildcard $(UFS_SYSTEMD_SRCDIR)),)\n\n'\
131 +'else\n'\
132 +'\t\0\n'\
133 +'endif~' -i stage1/usr_from_src/usr_from_src.mk || die
134 +
135 + # disable git fetch of kvmtool
136 + sed -e 's~^include makelib/git.mk$~'\
137 +'ifneq ($(wildcard $(shell echo "$${WORKDIR}/kvmtool")),)\n\n'\
138 +'$(call forward-vars, get_lkvm_sources, LKVM_SRCDIR)\n'\
139 +'get_lkvm_sources: | $(LKVM_TMPDIR)\n'\
140 +'\tmv "$${WORKDIR}/kvmtool" "$(LKVM_SRCDIR)"\n\n'\
141 +'$(LKVM_PATCH_STAMP): get_lkvm_sources\n\n'\
142 +'else ifneq ($(wildcard $(LKVM_SRCDIR)),)\n\n'\
143 +'else\n'\
144 +'\t\0\n'\
145 +'endif~' -i stage1/usr_from_kvm/lkvm.mk || die
146 +
147 + # disable git fetch of qemu
148 + sed -e 's~^include makelib/git.mk$~'\
149 +'ifneq ($(wildcard $(shell echo "$${WORKDIR}/qemu-'${QEMU_VERSION#v}'")),)\n\n'\
150 +'$(call forward-vars, get_qemu_sources, QEMU_SRCDIR)\n'\
151 +'get_qemu_sources: | $(QEMU_TMPDIR)\n'\
152 +'\tmv "$${WORKDIR}/qemu-'${QEMU_VERSION#v}'" "$(QEMU_SRCDIR)"\n\n'\
153 +'$(QEMU_CLONE_STAMP): get_qemu_sources\n\n'\
154 +'else ifneq ($(wildcard $(QEMU_SRCDIR)),)\n\n'\
155 +'else\n'\
156 +'\t\0\n'\
157 +'endif~' \
158 + -e 's|QEMU_CONFIGURATION_OPTS :=|\0 --disable-opengl|' \
159 + -i stage1/usr_from_kvm/qemu.mk || die
160 +
161 + # disable fetch of kernel sources
162 + sed -e 's|wget .*|ln -s "$${DISTDIR}/linux-'${KVM_LINUX_VERSION}'.tar.xz" "$@"|' \
163 + -i stage1/usr_from_kvm/kernel.mk || die
164 +
165 + if use rkt_stage1_host; then
166 + # Make systemdUnitsPath consistent with host
167 + sed -e 's|\(systemdUnitsPath := \).*|\1"'$(systemd_get_systemunitdir)'"|' \
168 + -i stage1/init/init.go || die
169 + fi
170 +
171 + eautoreconf
172 +}
173 +
174 +src_configure() {
175 + local flavors hypervisors myeconfargs=(
176 + --with-stage1-default-images-directory="/usr/share/rkt"
177 + --with-stage1-default-location="${STAGE1_DEFAULT_LOCATION}"
178 + )
179 +
180 + use systemd || myeconfargs+=( --enable-sdjournal=no )
181 +
182 + # enable flavors (first is default)
183 + use rkt_stage1_host && flavors+=",host"
184 + use rkt_stage1_src && flavors+=",src"
185 + use rkt_stage1_coreos && flavors+=",coreos"
186 + use rkt_stage1_fly && flavors+=",fly"
187 + { use rkt_stage1_kvm_lkvm || use rkt_stage1_kvm_qemu; } && flavors+=",kvm"
188 + myeconfargs+=( --with-stage1-flavors="${flavors#,}" )
189 +
190 + if use rkt_stage1_src; then
191 + myeconfargs+=(
192 + --with-stage1-systemd-version=${PXE_SYSTEMD_VERSION}
193 + --with-stage1-systemd-src="${WORKDIR}/systemd-${PXE_SYSTEMD_VERSION#v}"
194 + )
195 + fi
196 +
197 + if use rkt_stage1_coreos || use rkt_stage1_kvm_lkvm || use rkt_stage1_kvm_qemu; then
198 + myeconfargs+=(
199 + --with-coreos-local-pxe-image-path="${DISTDIR}/${PXE_FILE}"
200 + --with-coreos-local-pxe-image-systemd-version="${PXE_SYSTEMD_VERSION}"
201 + )
202 + fi
203 +
204 + if use rkt_stage1_kvm_lkvm || use rkt_stage1_kvm_qemu; then
205 + use rkt_stage1_kvm_lkvm && hypervisors+=",lkvm"
206 + use rkt_stage1_kvm_qemu && hypervisors+=",qemu"
207 + myeconfargs+=( --with-stage1-kvm-hypervisors="${hypervisors#,}" )
208 + fi
209 +
210 + # Go's 6l linker does not support PIE, disable so cgo binaries
211 + # which use 6l+gcc for linking can be built correctly.
212 + if gcc-specs-pie; then
213 + append-ldflags -nopie
214 + fi
215 +
216 + export CC=$(tc-getCC)
217 + export CGO_ENABLED=1
218 + export CGO_CFLAGS="${CFLAGS}"
219 + export CGO_CPPFLAGS="${CPPFLAGS}"
220 + export CGO_CXXFLAGS="${CXXFLAGS}"
221 + export CGO_LDFLAGS="${LDFLAGS}"
222 + export BUILDDIR
223 +
224 + econf "${myeconfargs[@]}"
225 +}
226 +
227 +src_compile() {
228 + local arch=${ARCH}
229 + case ${arch} in
230 + amd64) arch=x86_64;;
231 + esac
232 + ARCH=${arch} emake
233 + ARCH=${arch} emake bash-completion
234 +}
235 +
236 +src_install() {
237 + dodoc README.md
238 + use doc && dodoc -r Documentation
239 + use examples && dodoc -r examples
240 + use actool && dobin "${S}/${BUILDDIR}/tools/actool"
241 +
242 + dobin "${S}/${BUILDDIR}/target/bin/rkt"
243 +
244 + insinto /usr/share/rkt
245 + doins "${S}/${BUILDDIR}/target/bin/"*.aci
246 +
247 + # create symlink for default stage1 image path
248 + if use rkt_stage1_host; then
249 + dosym stage1-host.aci "${STAGE1_DEFAULT_LOCATION}"
250 + elif use rkt_stage1_src; then
251 + dosym stage1-src.aci "${STAGE1_DEFAULT_LOCATION}"
252 + elif use rkt_stage1_coreos; then
253 + dosym stage1-coreos.aci "${STAGE1_DEFAULT_LOCATION}"
254 + elif use rkt_stage1_fly; then
255 + dosym stage1-fly.aci "${STAGE1_DEFAULT_LOCATION}"
256 + elif use rkt_stage1_kvm_lkvm; then
257 + dosym stage1-kvm-lkvm.aci "${STAGE1_DEFAULT_LOCATION}"
258 + elif use rkt_stage1_kvm_qemu; then
259 + dosym stage1-kvm-qemu.aci "${STAGE1_DEFAULT_LOCATION}"
260 + fi
261 +
262 + systemd_dounit "${S}"/dist/init/systemd/${PN}-gc.service
263 + systemd_dounit "${S}"/dist/init/systemd/${PN}-gc.timer
264 + systemd_dounit "${S}"/dist/init/systemd/${PN}-metadata.service
265 + systemd_dounit "${S}"/dist/init/systemd/${PN}-metadata.socket
266 +
267 + newbashcomp "${S}"/dist/bash_completion/rkt.bash rkt
268 +
269 + keepdir /etc/${PN}
270 + fowners :rkt-admin /etc/${PN}
271 + fperms 2775 /etc/${PN}
272 +}