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