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, 26 Feb 2017 23:21:39
Message-Id: 1488151291.a852086179d0278d4c1e300375a12d8b14356466.zmedico@gentoo
1 commit: a852086179d0278d4c1e300375a12d8b14356466
2 Author: Zac Medico <zmedico <AT> gentoo <DOT> org>
3 AuthorDate: Sun Feb 26 23:20:32 2017 +0000
4 Commit: Zac Medico <zmedico <AT> gentoo <DOT> org>
5 CommitDate: Sun Feb 26 23:21:31 2017 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a8520861
7
8 app-emulation/rkt: version bump to 1.25.0
9
10 Package-Manager: Portage-2.3.3, Repoman-2.3.1
11
12 app-emulation/rkt/Manifest | 1 +
13 app-emulation/rkt/rkt-1.25.0.ebuild | 257 ++++++++++++++++++++++++++++++++++++
14 2 files changed, 258 insertions(+)
15
16 diff --git a/app-emulation/rkt/Manifest b/app-emulation/rkt/Manifest
17 index e508f3a3be..59b063ed6a 100644
18 --- a/app-emulation/rkt/Manifest
19 +++ b/app-emulation/rkt/Manifest
20 @@ -5,5 +5,6 @@ DIST qemu-2.7.0.tar.bz2 26867760 SHA256 326e739506ba690daf69fc17bd3913a6c313d992
21 DIST qemu-2.8.0.tar.bz2 28368517 SHA256 dafd5d7f649907b6b617b822692f4c82e60cf29bc0fc58bc2036219b591e5e62 SHA512 50f2988d822388ba9fd1bf5dbe68359033ed7432d7f0f9790299f32f63faa6dc72979256b5632ba572d47ee3e74ed40e3e8e331dc6303ec1599f1b4367cb78c2 WHIRLPOOL 0ce4e0539657eb832e4039819e7360c792b6aa41c718f0e0d762f4933217f0d370af94b1d6d9776853575b4a6811d8c85db069bf09d21bd15399ac8b50440ff5
22 DIST rkt-1.23.0.tar.gz 3350060 SHA256 5cb10a0646e5cc8dccbd099c40bc6b11264591b30fa8e4113bc9e392feffcb2b SHA512 9673f70b385a4e5c61c037783071507e69097f0d0163b3d449ca129bcdc858bc177d38c6551dc9f8b2f074345b4698863bbe62bf4d6c83f5df515406011ddce3 WHIRLPOOL 7d2e7b20205e6e00992091bd3898094b27e75f9e4716c73a0a31df2747cb77c49b11678db478ed7414cf12eef8c3463afded0e2d2a0b93effb9cce0edbed799a
23 DIST rkt-1.24.0.tar.gz 3359035 SHA256 ffeb9933d58a642a5dde4730eacde9a597345698120cf36283e02cf2ed085e2d SHA512 e5f30df83fc833f6a5f40c7e99207b38cbd01d078b26e9ea7d3587c3e57fe872e187850406fa5200c0245fb42b81223057eb561934004b57c3f2d57a31f3d269 WHIRLPOOL 842e58f90a676ee990c96e0dd4da42aad03dfb9201e7282565ce4f293a697ccb300a398ca66b14fe4ca73d5f4943582f58742a59098c091dcaf0a5bd1b094a6f
24 +DIST rkt-1.25.0.tar.gz 3385268 SHA256 090da380ae8526d2a819f777fa983aee0df6254c37eb1fd74783d2d4c4ced359 SHA512 7f61ef5a8f5d04545ac2015b19667f45d91a3e04d923bc492e05a71dec14d6cf4e5ed6464ede0cfb538328a780e013aca3e5cd7e3d9cdc029736f5b6498b1f74 WHIRLPOOL cebe2a2f76a7571a540c417a8f7e30cc2b69d72a89814ef58699212455101fdbbbeab5370b7efa45b2298e5b43344488d410100363a8595cfa7bb11006c94ff8
25 DIST rkt-pxe-1235.0.0.img 243713684 SHA256 988e4ad8e044dd8bff54cb5e0a34a1ed25cf7bc8cc241f1a90e3fe7f1412f315 SHA512 b19821c63b7b53a1aad3b6e279189f9ceed1f5db1a691d12a70eb7340cceb4c3fd4f7f61a913d9482aec5ce28740b9ee777f86a1ce54f597f50341d701372542 WHIRLPOOL f3905ce3a2a55a027197a2d11ca541323fdfd560d186b4a2c39a8f45e19811067d5de4fbd3656935b12787e1dec79d118d7a01d52a8ef7abd0dad4f38a222b1c
26 DIST systemd-231.tar.gz 4381464 SHA256 899733ad6c157cedbb89aec4efe3bc824dcfd65a1d6f6bebc7b043f7924e39b4 SHA512 199fa33a0494d1d15f7fe3c796fe14913ad386766571d4d3fbb1cb1c446e04f6d06a965213be4c594a7183e810fc2fd4804fe14f64f21b0a1278b717889811c6 WHIRLPOOL 7779291e9fb9873cb1773b8583cf6d4b7dec837363ea89c4a73c1e397a76752b66f8b57d8fc4d9cef768cc1855b5e325ad88a8a69eb5380aa924e0a6dead41b1
27
28 diff --git a/app-emulation/rkt/rkt-1.25.0.ebuild b/app-emulation/rkt/rkt-1.25.0.ebuild
29 new file mode 100644
30 index 0000000000..0d459fd8f6
31 --- /dev/null
32 +++ b/app-emulation/rkt/rkt-1.25.0.ebuild
33 @@ -0,0 +1,257 @@
34 +# Copyright 1999-2017 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="1235.0.0"
45 +PXE_SYSTEMD_VERSION="v231"
46 +KVM_LINUX_VERSION="4.9.2"
47 +KVMTOOL_VERSION="cfae4d64482ed745214e3c62dd84b79c2ae0f325"
48 +QEMU_VERSION="v2.8.0"
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 +# Some tests fail.
78 +# rkt_stage1_src needs to copy /bin/mount, which requires root privileges during src_compile
79 +RESTRICT="test rkt_stage1_src? ( userpriv )"
80 +
81 +DEPEND=">=dev-lang/go-1.5
82 + app-arch/cpio
83 + app-crypt/trousers
84 + sys-fs/squashfs-tools
85 + dev-perl/Capture-Tiny
86 + rkt_stage1_src? ( >=sys-apps/util-linux-2.27 )
87 + rkt_stage1_kvm_qemu? (
88 + sys-apps/attr[static-libs(+)]
89 + sys-libs/libcap[static-libs(+)]
90 + sys-libs/zlib[static-libs(+)]
91 + >=x11-libs/pixman-0.28.0[static-libs(+)]
92 + )"
93 +
94 +RDEPEND="!app-emulation/rocket
95 + rkt_stage1_host? ( systemd? (
96 + >=sys-apps/systemd-222
97 + app-shells/bash:0
98 + ) )"
99 +
100 +BUILDDIR="build-${P}"
101 +STAGE1_DEFAULT_LOCATION="/usr/share/rkt/stage1.aci"
102 +
103 +pkg_setup() {
104 + enewgroup rkt-admin
105 + enewgroup rkt
106 +}
107 +
108 +src_unpack() {
109 + local x
110 + for x in ${A}; do
111 + case ${x} in
112 + *.img|linux-*) continue ;;
113 + kvmtool-*)
114 + mkdir kvmtool || die
115 + pushd kvmtool >/dev/null || die
116 + unpack ${x}
117 + popd >/dev/null || die
118 + ;;
119 + *)
120 + unpack ${x}
121 + esac
122 + done
123 +}
124 +
125 +src_prepare() {
126 + eapply_user
127 +
128 + # This patch breaks linux kernel cc-option checks when the
129 + # compiler doesn't recognize the -no-pie option.
130 + rm stage1/usr_from_kvm/kernel/patches/0002-for-debian-gcc.patch || die
131 +
132 + # avoid sdjournal include for bug 595874
133 + if ! use systemd; then
134 + sed -e "s/^\\(LOCAL_DIST_SRC_FILTER := .*\\)'$/\\1|api_service'/" \
135 + -i rkt/rkt.mk || die
136 + fi
137 +
138 + sed -e 's|^RKT_REQ_PROG(\[GIT\],.*|#\0|' -i configure.ac || die
139 +
140 + # disable git fetch of systemd
141 + sed -e 's~^include makelib/git.mk$~'\
142 +'ifneq ($(wildcard $(RKT_STAGE1_SYSTEMD_SRC)),)\n\n'\
143 +'get_systemd_sources: | $(UFS_SYSTEMDDIR)\n'\
144 +'\tmv "$(RKT_STAGE1_SYSTEMD_SRC)" "$(UFS_SYSTEMD_SRCDIR)"\n\n'\
145 +'$(UFS_SYSTEMD_CONFIGURE): get_systemd_sources\n\n'\
146 +'else ifneq ($(wildcard $(UFS_SYSTEMD_SRCDIR)),)\n\n'\
147 +'else\n'\
148 +'\t\0\n'\
149 +'endif~' -i stage1/usr_from_src/usr_from_src.mk || die
150 +
151 + # disable git fetch of kvmtool
152 + sed -e 's~^include makelib/git.mk$~'\
153 +'ifneq ($(wildcard $(shell echo "$${WORKDIR}/kvmtool")),)\n\n'\
154 +'$(call forward-vars, get_lkvm_sources, LKVM_SRCDIR)\n'\
155 +'get_lkvm_sources: | $(LKVM_TMPDIR)\n'\
156 +'\tmv "$${WORKDIR}/kvmtool" "$(LKVM_SRCDIR)"\n\n'\
157 +'$(LKVM_PATCH_STAMP): get_lkvm_sources\n\n'\
158 +'else ifneq ($(wildcard $(LKVM_SRCDIR)),)\n\n'\
159 +'else\n'\
160 +'\t\0\n'\
161 +'endif~' -i stage1/usr_from_kvm/lkvm.mk || die
162 +
163 + # disable git fetch of qemu
164 + sed -e 's~^include makelib/git.mk$~'\
165 +'ifneq ($(wildcard $(shell echo "$${WORKDIR}/qemu-'${QEMU_VERSION#v}'")),)\n\n'\
166 +'$(call forward-vars, get_qemu_sources, QEMU_SRCDIR)\n'\
167 +'get_qemu_sources: | $(QEMU_TMPDIR)\n'\
168 +'\tmv "$${WORKDIR}/qemu-'${QEMU_VERSION#v}'" "$(QEMU_SRCDIR)"\n\n'\
169 +'$(QEMU_CONF_STAMP): get_qemu_sources\n\n'\
170 +'else ifneq ($(wildcard $(QEMU_SRCDIR)),)\n\n'\
171 +'else\n'\
172 +'\t\0\n'\
173 +'endif~' \
174 + -e 's|QEMU_CONFIGURATION_OPTS :=|\0 --disable-bzip2 --disable-libssh2 --disable-opengl|' \
175 + -i stage1/usr_from_kvm/qemu.mk || die
176 +
177 + # disable fetch of kernel sources
178 + sed -e 's|wget .*|ln -s "$${DISTDIR}/linux-'${KVM_LINUX_VERSION}'.tar.xz" "$@"|' \
179 + -i stage1/usr_from_kvm/kernel.mk || die
180 +
181 + if use rkt_stage1_host; then
182 + # Make systemdUnitsPath consistent with host
183 + sed -e 's|\(systemdUnitsPath := \).*|\1"'$(systemd_get_systemunitdir)'"|' \
184 + -i stage1/init/init.go || die
185 + fi
186 +
187 + eautoreconf
188 +}
189 +
190 +src_configure() {
191 + local flavors hypervisors myeconfargs=(
192 + --with-stage1-default-images-directory="/usr/share/rkt"
193 + --with-stage1-default-location="${STAGE1_DEFAULT_LOCATION}"
194 + )
195 +
196 + use systemd || myeconfargs+=( --enable-sdjournal=no )
197 +
198 + # enable flavors (first is default)
199 + use rkt_stage1_host && flavors+=",host"
200 + use rkt_stage1_src && flavors+=",src"
201 + use rkt_stage1_coreos && flavors+=",coreos"
202 + use rkt_stage1_fly && flavors+=",fly"
203 + { use rkt_stage1_kvm_lkvm || use rkt_stage1_kvm_qemu; } && flavors+=",kvm"
204 + myeconfargs+=( --with-stage1-flavors="${flavors#,}" )
205 +
206 + if use rkt_stage1_src; then
207 + myeconfargs+=(
208 + --with-stage1-systemd-version=${PXE_SYSTEMD_VERSION}
209 + --with-stage1-systemd-src="${WORKDIR}/systemd-${PXE_SYSTEMD_VERSION#v}"
210 + )
211 + fi
212 +
213 + if use rkt_stage1_coreos || use rkt_stage1_kvm_lkvm || use rkt_stage1_kvm_qemu; then
214 + myeconfargs+=(
215 + --with-coreos-local-pxe-image-path="${DISTDIR}/${PXE_FILE}"
216 + --with-coreos-local-pxe-image-systemd-version="${PXE_SYSTEMD_VERSION}"
217 + )
218 + fi
219 +
220 + if use rkt_stage1_kvm_lkvm || use rkt_stage1_kvm_qemu; then
221 + use rkt_stage1_kvm_lkvm && hypervisors+=",lkvm"
222 + use rkt_stage1_kvm_qemu && hypervisors+=",qemu"
223 + myeconfargs+=( --with-stage1-kvm-hypervisors="${hypervisors#,}" )
224 + fi
225 +
226 + # Go's 6l linker does not support PIE, disable so cgo binaries
227 + # which use 6l+gcc for linking can be built correctly.
228 + if gcc-specs-pie; then
229 + append-ldflags -nopie
230 + fi
231 +
232 + export CC=$(tc-getCC)
233 + export CGO_ENABLED=1
234 + export CGO_CFLAGS="${CFLAGS}"
235 + export CGO_CPPFLAGS="${CPPFLAGS}"
236 + export CGO_CXXFLAGS="${CXXFLAGS}"
237 + export CGO_LDFLAGS="${LDFLAGS}"
238 + export BUILDDIR
239 +
240 + econf "${myeconfargs[@]}"
241 +}
242 +
243 +src_compile() {
244 + local arch=${ARCH}
245 + case ${arch} in
246 + amd64) arch=x86_64;;
247 + esac
248 + ARCH=${arch} emake V=3
249 + ARCH=${arch} emake V=3 bash-completion
250 +}
251 +
252 +src_install() {
253 + dodoc README.md
254 + use doc && dodoc -r Documentation
255 + use examples && dodoc -r examples
256 + use actool && dobin "${S}/${BUILDDIR}/tools/actool"
257 +
258 + dobin "${S}/${BUILDDIR}/target/bin/rkt"
259 +
260 + insinto /usr/share/rkt
261 + doins "${S}/${BUILDDIR}/target/bin/"*.aci
262 +
263 + # create symlink for default stage1 image path
264 + if use rkt_stage1_host; then
265 + dosym stage1-host.aci "${STAGE1_DEFAULT_LOCATION}"
266 + elif use rkt_stage1_src; then
267 + dosym stage1-src.aci "${STAGE1_DEFAULT_LOCATION}"
268 + elif use rkt_stage1_coreos; then
269 + dosym stage1-coreos.aci "${STAGE1_DEFAULT_LOCATION}"
270 + elif use rkt_stage1_fly; then
271 + dosym stage1-fly.aci "${STAGE1_DEFAULT_LOCATION}"
272 + elif use rkt_stage1_kvm_lkvm; then
273 + dosym stage1-kvm-lkvm.aci "${STAGE1_DEFAULT_LOCATION}"
274 + elif use rkt_stage1_kvm_qemu; then
275 + dosym stage1-kvm-qemu.aci "${STAGE1_DEFAULT_LOCATION}"
276 + fi
277 +
278 + systemd_dounit "${S}"/dist/init/systemd/*.service \
279 + "${S}"/dist/init/systemd/*.timer \
280 + "${S}"/dist/init/systemd/*.socket
281 +
282 + insinto /usr/lib/tmpfiles.d
283 + doins "${S}"/dist/init/systemd/tmpfiles.d/*
284 +
285 + newbashcomp "${S}"/dist/bash_completion/rkt.bash rkt
286 +
287 + keepdir /etc/${PN}
288 + fowners :rkt-admin /etc/${PN}
289 + fperms 2775 /etc/${PN}
290 +}