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