diff options
author | Jason Zaman <perfinion@gentoo.org> | 2019-07-03 13:08:22 +0800 |
---|---|---|
committer | Jason Zaman <perfinion@gentoo.org> | 2019-07-03 13:49:10 +0800 |
commit | 554a3365c8a6807a02976a55462a9708638457e2 (patch) | |
tree | 0b26d2994bc9b36defd655439dbce14367f9885a /dev-util | |
parent | net-wireless/dump1090: wip update to fa fork (diff) | |
download | gentoo-554a3365c8a6807a02976a55462a9708638457e2.tar.gz gentoo-554a3365c8a6807a02976a55462a9708638457e2.tar.bz2 gentoo-554a3365c8a6807a02976a55462a9708638457e2.zip |
dev-util/bazel: respect CFLAGS
The bazelrc was not used by the build so pass the flags directly to
bazel extra flags.
Thanks to Michael Martis for triaging and finding the fix.
Signed-off-by: Jason Zaman <perfinion@gentoo.org>
Package-Manager: Portage-2.3.66, Repoman-2.3.11
Diffstat (limited to 'dev-util')
-rw-r--r-- | dev-util/bazel/bazel-0.24.1-r1.ebuild (renamed from dev-util/bazel/bazel-0.27.0.ebuild) | 17 | ||||
-rw-r--r-- | dev-util/bazel/bazel-0.26.1-r1.ebuild (renamed from dev-util/bazel/bazel-0.26.1.ebuild) | 19 | ||||
-rw-r--r-- | dev-util/bazel/bazel-0.27.0-r1.ebuild | 108 |
3 files changed, 113 insertions, 31 deletions
diff --git a/dev-util/bazel/bazel-0.27.0.ebuild b/dev-util/bazel/bazel-0.24.1-r1.ebuild index 3011c92b93f3..a1d730d57133 100644 --- a/dev-util/bazel/bazel-0.27.0.ebuild +++ b/dev-util/bazel/bazel-0.24.1-r1.ebuild @@ -22,7 +22,6 @@ DEPEND="${RDEPEND} app-arch/zip" S="${WORKDIR}" -QA_FLAGS_IGNORED="usr/bin/bazel" bazel-get-flags() { local i fs=() @@ -63,23 +62,10 @@ src_prepare() { # 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 || die - 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) --host_javabase=@local_jdk//:jdk" + export EXTRA_BAZEL_ARGS="--jobs=$(makeopts_jobs) $(bazel-get-flags) --host_javabase=@local_jdk//:jdk" VERBOSE=yes ./compile.sh || die ./scripts/generate_bash_completion.sh \ @@ -117,5 +103,6 @@ src_install() { docinto tools dodoc -r tools/* docompress -x /usr/share/doc/${PF}/tools + docompress -x /usr/share/doc/${PF}/tools/build_defs/pkg/testdata fi } diff --git a/dev-util/bazel/bazel-0.26.1.ebuild b/dev-util/bazel/bazel-0.26.1-r1.ebuild index f423e4855300..a1d730d57133 100644 --- a/dev-util/bazel/bazel-0.26.1.ebuild +++ b/dev-util/bazel/bazel-0.26.1-r1.ebuild @@ -16,13 +16,12 @@ KEYWORDS="~amd64" IUSE="examples test tools" # strip corrupts the bazel binary RESTRICT="strip test? ( network-sandbox ) !test? ( test )" -RDEPEND=">=virtual/jdk-1.8" +RDEPEND=">=virtual/jdk-1.8:*" DEPEND="${RDEPEND} app-arch/unzip app-arch/zip" S="${WORKDIR}" -QA_FLAGS_IGNORED="usr/bin/bazel" bazel-get-flags() { local i fs=() @@ -63,23 +62,10 @@ src_prepare() { # 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 || die - 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) --host_javabase=@local_jdk//:jdk" + export EXTRA_BAZEL_ARGS="--jobs=$(makeopts_jobs) $(bazel-get-flags) --host_javabase=@local_jdk//:jdk" VERBOSE=yes ./compile.sh || die ./scripts/generate_bash_completion.sh \ @@ -117,5 +103,6 @@ src_install() { docinto tools dodoc -r tools/* docompress -x /usr/share/doc/${PF}/tools + docompress -x /usr/share/doc/${PF}/tools/build_defs/pkg/testdata fi } diff --git a/dev-util/bazel/bazel-0.27.0-r1.ebuild b/dev-util/bazel/bazel-0.27.0-r1.ebuild new file mode 100644 index 000000000000..a1d730d57133 --- /dev/null +++ b/dev-util/bazel/bazel-0.27.0-r1.ebuild @@ -0,0 +1,108 @@ +# Copyright 1999-2019 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +inherit bash-completion-r1 java-pkg-2 multiprocessing + +DESCRIPTION="Fast and correct automated build system" +HOMEPAGE="https://bazel.build/" + +SRC_URI="https://github.com/bazelbuild/bazel/releases/download/${PV}/${P}-dist.zip" + +LICENSE="Apache-2.0" +SLOT="0" +KEYWORDS="~amd64" +IUSE="examples test tools" +# strip corrupts the bazel binary +RESTRICT="strip test? ( network-sandbox ) !test? ( test )" +RDEPEND=">=virtual/jdk-1.8:*" +DEPEND="${RDEPEND} + app-arch/unzip + app-arch/zip" + +S="${WORKDIR}" + +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 + + # F: fopen_wr + # S: deny + # P: /proc/self/setgroups + # A: /proc/self/setgroups + # R: /proc/24939/setgroups + # C: /usr/lib/systemd/systemd + addpredict /proc +} + +src_compile() { + export EXTRA_BAZEL_ARGS="--jobs=$(makeopts_jobs) $(bazel-get-flags) --host_javabase=@local_jdk//:jdk" + VERBOSE=yes ./compile.sh || die + + ./scripts/generate_bash_completion.sh \ + --bazel=output/bazel \ + --output=bazel-complete.bash \ + --prepend=scripts/bazel-complete-header.bash \ + --prepend=scripts/bazel-complete-template.bash +} + +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-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 + docompress -x /usr/share/doc/${PF}/tools/build_defs/pkg/testdata + fi +} |