diff options
author | Jason Zaman <perfinion@gentoo.org> | 2018-11-16 16:17:01 +0800 |
---|---|---|
committer | Jason Zaman <perfinion@gentoo.org> | 2018-11-18 01:31:19 +0800 |
commit | 48acaad70cd384e76be3aeea79b5a11b4f762fe6 (patch) | |
tree | b0321cb1d8261c5ceb8c62c3c0b0dfb505103da5 /dev-util | |
parent | app-office/gnumeric: add missing DTD to DEPEND (diff) | |
download | gentoo-48acaad70cd384e76be3aeea79b5a11b4f762fe6.tar.gz gentoo-48acaad70cd384e76be3aeea79b5a11b4f762fe6.tar.bz2 gentoo-48acaad70cd384e76be3aeea79b5a11b4f762fe6.zip |
dev-util/bazel: bump to 0.19.0
Closes: https://bugs.gentoo.org/669950
Signed-off-by: Jason Zaman <perfinion@gentoo.org>
Package-Manager: Portage-2.3.51, Repoman-2.3.11
Diffstat (limited to 'dev-util')
-rw-r--r-- | dev-util/bazel/Manifest | 1 | ||||
-rw-r--r-- | dev-util/bazel/bazel-0.19.0.ebuild | 125 |
2 files changed, 126 insertions, 0 deletions
diff --git a/dev-util/bazel/Manifest b/dev-util/bazel/Manifest index 118c5d73044d..5947b51ba1c7 100644 --- a/dev-util/bazel/Manifest +++ b/dev-util/bazel/Manifest @@ -1,2 +1,3 @@ DIST bazel-0.17.2-dist.zip 79230155 BLAKE2B 62a60011f9605a1d615e648fdbb98b193561e1d86a7562ccb10fdbb8b6986e17a72c4076dbdbf6baf8a7af83e320af2c4e4b65b5b2101d845597ddd688194ba5 SHA512 0d277e20eac6fc972a31be1c77a750f6585d16beabfe7dd096db4103f0f191958aa83b52203b91d4df5b486ff20004c0b4b22125e58379f64f68abc4a87ac326 DIST bazel-0.18.0-dist.zip 86890953 BLAKE2B 53da2c2d4467f1f7dd2e613a347acd0ea547bd41fe49fa39cbbcb92c337dca43412ac9b65abf7a3e00c322b8fea075cbdef0da5b064bf4e22aaaa4c545c539de SHA512 128e1041ae0d85be26933bb107b406ca4ab177f00eec2ee1d791ec9089c0cb384857b532498276480d1063b82e7a9a809b9f8a0d0715260534c3e3d202d6cf13 +DIST bazel-0.19.0-dist.zip 87333329 BLAKE2B a9a0002b6a1dc98d3c753b9e37001f41c0e9b3e8628600d10d7ffb379686a2fef33032b8264e72cb787135be0a5a3c26aa452320b309da10ed8a1f8fe6667046 SHA512 ea67fb4d13487d24a0442084f42ff3c082a107c56a06d882f579064f17c545d6e9b5f0c4d724238c22e9b3bad12c68c60c58b59f82d9e957fe3af222d44bc969 diff --git a/dev-util/bazel/bazel-0.19.0.ebuild b/dev-util/bazel/bazel-0.19.0.ebuild new file mode 100644 index 000000000000..dda30d679453 --- /dev/null +++ b/dev-util/bazel/bazel-0.19.0.ebuild @@ -0,0 +1,125 @@ +# Copyright 1999-2018 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=6 + +inherit bash-completion-r1 java-pkg-2 multiprocessing + +DESCRIPTION="Fast and correct automated build system" +HOMEPAGE="http://bazel.io/" + +SRC_URI="https://github.com/bazelbuild/bazel/releases/download/${PV}/${P}-dist.zip" + +LICENSE="Apache-2.0" +SLOT="0" +KEYWORDS="~amd64" +IUSE="examples tools" +# strip corrupts the bazel binary +RESTRICT="strip" +RDEPEND="virtual/jdk:1.8" +DEPEND="${RDEPEND} + app-arch/unzip" + +S="${WORKDIR}" +QA_FLAGS_IGNORED="usr/bin/bazel" + +bazel-get-flags() { + local i fs=() + for i in ${CFLAGS}; do + fs+=( "--copt=${i}" "--host_copt=${i}" ) + done + for i in ${CXXFLAGS}; do + fs+=( "--cxxopt=${i}" "--host_cxxopt=${i}" ) + done + for i in ${CPPFLAGS}; do + fs+=( "--copt=${i}" "--host_copt=${i}" ) + fs+=( "--cxxopt=${i}" "--host_cxxopt=${i}" ) + done + for i in ${LDFLAGS}; do + fs+=( "--linkopt=${i}" "--host_linkopt=${i}" ) + done + echo "${fs[*]}" +} + +pkg_setup() { + echo ${PATH} | grep -q ccache && \ + ewarn "${PN} usually fails to compile with ccache, you have been warned" + java-pkg-2_pkg_setup +} + +src_unpack() { + # Only unpack the main distfile + unpack ${P}-dist.zip +} + +src_prepare() { + default + + sed -i 's@//src:bazel@//src:bazel_nojdk@' scripts/BUILD || die + + # F: fopen_wr + # S: deny + # P: /proc/self/setgroups + # A: /proc/self/setgroups + # R: /proc/24939/setgroups + # C: /usr/lib/systemd/systemd + addpredict /proc + + # Use standalone strategy to deactivate the bazel sandbox, since it + # conflicts with FEATURES=sandbox. + cat > "${T}/bazelrc" <<-EOF + build --verbose_failures + build --spawn_strategy=standalone --genrule_strategy=standalone + + build --distdir=${S}/derived/distdir/ + build --jobs=$(makeopts_jobs) $(bazel-get-flags) + + test --verbose_failures --verbose_test_summary + test --spawn_strategy=standalone --genrule_strategy=standalone + EOF +} + +src_compile() { + export EXTRA_BAZEL_ARGS="--jobs=$(makeopts_jobs)" + VERBOSE=yes ./compile.sh || die + + local OPTS="" + if [[ $(java-config -g PROVIDES_VERSION) == "1.8" ]]; then + OPTS="--java_toolchain=@bazel_tools//tools/jdk:toolchain_hostjdk8" + OPTS+=" --host_java_toolchain=@bazel_tools//tools/jdk:toolchain_hostjdk8" + fi + + output/bazel --bazelrc="${T}/bazelrc" build ${OPTS} //scripts:bazel-complete.bash || die + output/bazel shutdown +} + +src_test() { + output/bazel test \ + --verbose_failures \ + --spawn_strategy=standalone \ + --genrule_strategy=standalone \ + --verbose_test_summary \ + examples/cpp:hello-success_test || die + output/bazel shutdown +} + +src_install() { + dobin output/bazel + newbashcomp bazel-bin/scripts/bazel-complete.bash ${PN} + bashcomp_alias ${PN} ibazel + insinto /usr/share/zsh/site-functions + doins scripts/zsh_completion/_bazel + + if use examples; then + docinto examples + dodoc -r examples/* + docompress -x /usr/share/doc/${PF}/examples + fi + # could really build tools but I don't know which ones + # are actually used + if use tools; then + docinto tools + dodoc -r tools/* + docompress -x /usr/share/doc/${PF}/tools + fi +} |