2019-01-15 14:14:33 +00:00
|
|
|
|
{ stdenv, callPackage, lib, fetchurl, fetchpatch, runCommand, makeWrapper
|
2018-07-14 16:36:42 +01:00
|
|
|
|
, jdk, zip, unzip, bash, writeCBin, coreutils
|
2018-11-19 18:08:48 +00:00
|
|
|
|
, which, python, perl, gawk, gnused, gnugrep, findutils
|
2018-09-10 06:12:22 +01:00
|
|
|
|
# Apple dependencies
|
|
|
|
|
, cctools, clang, libcxx, CoreFoundation, CoreServices, Foundation
|
|
|
|
|
# Allow to independently override the jdks used to build and run respectively
|
|
|
|
|
, buildJdk ? jdk, runJdk ? jdk
|
2017-11-10 17:05:55 +00:00
|
|
|
|
# Always assume all markers valid (don't redownload dependencies).
|
|
|
|
|
# Also, don't clean up environment variables.
|
|
|
|
|
, enableNixHacks ? false
|
|
|
|
|
}:
|
2016-10-09 04:54:12 +01:00
|
|
|
|
|
2018-07-14 16:36:42 +01:00
|
|
|
|
let
|
2018-08-21 12:11:12 +01:00
|
|
|
|
srcDeps = lib.singleton (
|
2018-07-14 16:36:42 +01:00
|
|
|
|
fetchurl {
|
2019-01-04 17:06:39 +00:00
|
|
|
|
url = "https://github.com/google/desugar_jdk_libs/archive/915f566d1dc23bc5a8975320cd2ff71be108eb9c.zip";
|
|
|
|
|
sha256 = "0b926df7yxyyyiwm9cmdijy6kplf0sghm23sf163zh8wrk87wfi7";
|
2018-07-14 16:36:42 +01:00
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
distDir = runCommand "bazel-deps" {} ''
|
|
|
|
|
mkdir -p $out
|
|
|
|
|
for i in ${builtins.toString srcDeps}; do cp $i $out/$(stripHash $i); done
|
|
|
|
|
'';
|
|
|
|
|
|
2018-11-19 18:08:48 +00:00
|
|
|
|
defaultShellPath = lib.makeBinPath [ bash coreutils findutils gawk gnugrep gnused which unzip ];
|
2018-07-14 16:36:42 +01:00
|
|
|
|
|
2018-07-15 21:54:26 +01:00
|
|
|
|
in
|
2017-02-15 15:40:27 +00:00
|
|
|
|
stdenv.mkDerivation rec {
|
2016-10-09 04:54:12 +01:00
|
|
|
|
|
2019-01-04 17:06:39 +00:00
|
|
|
|
version = "0.21.0";
|
2016-10-09 04:54:12 +01:00
|
|
|
|
|
2018-08-21 12:11:12 +01:00
|
|
|
|
meta = with lib; {
|
2017-09-03 12:56:21 +01:00
|
|
|
|
homepage = "https://github.com/bazelbuild/bazel/";
|
2016-10-09 04:54:12 +01:00
|
|
|
|
description = "Build tool that builds code quickly and reliably";
|
|
|
|
|
license = licenses.asl20;
|
2018-05-14 06:57:34 +01:00
|
|
|
|
maintainers = [ maintainers.mboes ];
|
2018-05-23 08:18:44 +01:00
|
|
|
|
platforms = platforms.linux ++ platforms.darwin;
|
2016-10-09 04:54:12 +01:00
|
|
|
|
};
|
|
|
|
|
|
2019-01-15 14:14:33 +00:00
|
|
|
|
# additional tests that check bazel’s functionality
|
|
|
|
|
passthru.tests = {
|
2019-01-22 15:47:17 +00:00
|
|
|
|
pythonBinPath = callPackage ./python-bin-path-test.nix {};
|
2019-01-15 14:14:33 +00:00
|
|
|
|
};
|
|
|
|
|
|
2017-02-15 15:40:27 +00:00
|
|
|
|
name = "bazel-${version}";
|
2016-10-09 04:54:12 +01:00
|
|
|
|
|
2017-02-15 15:40:27 +00:00
|
|
|
|
src = fetchurl {
|
|
|
|
|
url = "https://github.com/bazelbuild/bazel/releases/download/${version}/bazel-${version}-dist.zip";
|
2019-01-04 17:06:39 +00:00
|
|
|
|
sha256 = "1d3x0f1hzaiqq00pd65bks7v8kbv57m13jsing7y0y9id0g87jvc";
|
2015-03-25 15:12:02 +00:00
|
|
|
|
};
|
2016-10-09 04:54:12 +01:00
|
|
|
|
|
2017-02-15 15:40:27 +00:00
|
|
|
|
sourceRoot = ".";
|
|
|
|
|
|
2019-01-15 14:14:33 +00:00
|
|
|
|
patches = [
|
|
|
|
|
./python-stub-path-fix.patch
|
2019-01-15 22:15:22 +00:00
|
|
|
|
] ++ lib.optional enableNixHacks ./nix-hacks.patch;
|
2017-11-10 17:05:55 +00:00
|
|
|
|
|
2017-09-03 12:56:21 +01:00
|
|
|
|
# Bazel expects several utils to be available in Bash even without PATH. Hence this hack.
|
|
|
|
|
|
2018-05-23 08:18:44 +01:00
|
|
|
|
customBash = writeCBin "bash" ''
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
#include <string.h>
|
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
|
|
extern char **environ;
|
|
|
|
|
|
|
|
|
|
int main(int argc, char *argv[]) {
|
|
|
|
|
char *path = getenv("PATH");
|
2018-07-14 16:36:42 +01:00
|
|
|
|
char *pathToAppend = "${defaultShellPath}";
|
2018-05-23 08:18:44 +01:00
|
|
|
|
char *newPath;
|
|
|
|
|
if (path != NULL) {
|
|
|
|
|
int length = strlen(path) + 1 + strlen(pathToAppend) + 1;
|
|
|
|
|
newPath = malloc(length * sizeof(char));
|
|
|
|
|
snprintf(newPath, length, "%s:%s", path, pathToAppend);
|
|
|
|
|
} else {
|
|
|
|
|
newPath = pathToAppend;
|
|
|
|
|
}
|
|
|
|
|
setenv("PATH", newPath, 1);
|
|
|
|
|
execve("${bash}/bin/bash", argv, environ);
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
2017-09-03 12:56:21 +01:00
|
|
|
|
'';
|
|
|
|
|
|
2018-08-21 12:11:12 +01:00
|
|
|
|
postPatch = let
|
2019-01-04 17:06:39 +00:00
|
|
|
|
|
2018-08-21 12:11:12 +01:00
|
|
|
|
darwinPatches = ''
|
|
|
|
|
# Disable Bazel's Xcode toolchain detection which would configure compilers
|
|
|
|
|
# and linkers from Xcode instead of from PATH
|
|
|
|
|
export BAZEL_USE_CPP_ONLY_TOOLCHAIN=1
|
|
|
|
|
|
2018-09-15 14:43:57 +01:00
|
|
|
|
# Explicitly configure gcov since we don't have it on Darwin, so autodetection fails
|
|
|
|
|
export GCOV=${coreutils}/bin/false
|
|
|
|
|
|
2018-08-21 12:11:12 +01:00
|
|
|
|
# Framework search paths aren't added by bintools hook
|
|
|
|
|
# https://github.com/NixOS/nixpkgs/pull/41914
|
|
|
|
|
export NIX_LDFLAGS="$NIX_LDFLAGS -F${CoreFoundation}/Library/Frameworks -F${CoreServices}/Library/Frameworks -F${Foundation}/Library/Frameworks"
|
|
|
|
|
|
|
|
|
|
# libcxx includes aren't added by libcxx hook
|
|
|
|
|
# https://github.com/NixOS/nixpkgs/pull/41589
|
|
|
|
|
export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -isystem ${libcxx}/include/c++/v1"
|
|
|
|
|
|
2018-09-15 14:43:57 +01:00
|
|
|
|
# 10.10 apple_sdk Foundation doesn't have type arguments on classes
|
|
|
|
|
# Remove this when we update apple_sdk
|
|
|
|
|
sed -i -e 's/<.*\*>//g' tools/osx/xcode_locator.m
|
|
|
|
|
|
2018-08-21 12:11:12 +01:00
|
|
|
|
# don't use system installed Xcode to run clang, use Nix clang instead
|
|
|
|
|
sed -i -e "s;/usr/bin/xcrun clang;${clang}/bin/clang $NIX_CFLAGS_COMPILE $NIX_LDFLAGS -framework CoreFoundation;g" \
|
|
|
|
|
scripts/bootstrap/compile.sh \
|
|
|
|
|
src/tools/xcode/realpath/BUILD \
|
|
|
|
|
src/tools/xcode/stdredirect/BUILD \
|
|
|
|
|
tools/osx/BUILD
|
|
|
|
|
|
|
|
|
|
# clang installed from Xcode has a compatibility wrapper that forwards
|
|
|
|
|
# invocations of gcc to clang, but vanilla clang doesn't
|
|
|
|
|
sed -i -e 's;_find_generic(repository_ctx, "gcc", "CC", overriden_tools);_find_generic(repository_ctx, "clang", "CC", overriden_tools);g' tools/cpp/unix_cc_configure.bzl
|
|
|
|
|
|
|
|
|
|
sed -i -e 's;/usr/bin/libtool;${cctools}/bin/libtool;g' tools/cpp/unix_cc_configure.bzl
|
|
|
|
|
wrappers=( tools/cpp/osx_cc_wrapper.sh tools/cpp/osx_cc_wrapper.sh.tpl )
|
|
|
|
|
for wrapper in "''${wrappers[@]}"; do
|
|
|
|
|
sed -i -e "s,/usr/bin/install_name_tool,${cctools}/bin/install_name_tool,g" $wrapper
|
|
|
|
|
done
|
|
|
|
|
'';
|
2019-01-04 17:06:39 +00:00
|
|
|
|
|
2018-08-21 12:11:12 +01:00
|
|
|
|
genericPatches = ''
|
2019-01-15 14:14:33 +00:00
|
|
|
|
# Substitute python's stub shebang to plain python path. (see TODO add pr URL)
|
2019-01-22 15:42:41 +00:00
|
|
|
|
# See also `postFixup` where python is added to $out/nix-support
|
2019-01-15 14:14:33 +00:00
|
|
|
|
substituteInPlace src/main/java/com/google/devtools/build/lib/bazel/rules/python/python_stub_template.txt\
|
|
|
|
|
--replace "/usr/bin/env python" "${python}/bin/python" \
|
|
|
|
|
--replace "NIX_STORE_PYTHON_PATH" "${python}/bin/python" \
|
2019-01-22 15:42:41 +00:00
|
|
|
|
|
2019-01-04 17:05:03 +00:00
|
|
|
|
# substituteInPlace is rather slow, so prefilter the files with grep
|
|
|
|
|
grep -rlZ /bin src/main/java/com/google/devtools | while IFS="" read -r -d "" path; do
|
|
|
|
|
# If you add more replacements here, you must change the grep above!
|
|
|
|
|
# Only files containing /bin are taken into account.
|
2018-08-21 12:11:12 +01:00
|
|
|
|
substituteInPlace "$path" \
|
|
|
|
|
--replace /bin/bash ${customBash}/bin/bash \
|
2018-12-17 22:21:14 +00:00
|
|
|
|
--replace /usr/bin/env ${coreutils}/bin/env \
|
|
|
|
|
--replace /bin/true ${coreutils}/bin/true
|
2018-08-21 12:11:12 +01:00
|
|
|
|
done
|
2019-01-04 17:06:39 +00:00
|
|
|
|
|
2018-08-21 12:11:12 +01:00
|
|
|
|
# Fixup scripts that generate scripts. Not fixed up by patchShebangs below.
|
|
|
|
|
substituteInPlace scripts/bootstrap/compile.sh \
|
|
|
|
|
--replace /bin/sh ${customBash}/bin/bash
|
|
|
|
|
|
2019-01-04 17:06:39 +00:00
|
|
|
|
# We only build with JDK8 for now, since JDK11 does not compile bazel
|
|
|
|
|
substituteInPlace tools/jdk/default_java_toolchain.bzl \
|
|
|
|
|
--replace '"jvm_opts": JDK9_JVM_OPTS' \
|
|
|
|
|
'"jvm_opts": JDK8_JVM_OPTS'
|
|
|
|
|
|
|
|
|
|
# add nix environment vars to .bazelrc
|
|
|
|
|
cat >> .bazelrc <<EOF
|
|
|
|
|
build --experimental_distdir=${distDir}
|
|
|
|
|
fetch --experimental_distdir=${distDir}
|
|
|
|
|
build --copt="$(echo $NIX_CFLAGS_COMPILE | sed -e 's/ /" --copt="/g')"
|
|
|
|
|
build --host_copt="$(echo $NIX_CFLAGS_COMPILE | sed -e 's/ /" --host_copt="/g')"
|
|
|
|
|
build --linkopt="-Wl,$(echo $NIX_LDFLAGS | sed -e 's/ /" --linkopt="-Wl,/g')"
|
|
|
|
|
build --host_linkopt="-Wl,$(echo $NIX_LDFLAGS | sed -e 's/ /" --host_linkopt="-Wl,/g')"
|
|
|
|
|
build --host_javabase='@local_jdk//:jdk'
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
# add the same environment vars to compile.sh
|
|
|
|
|
sed -e "/\$command \\\\$/a --copt=\"$(echo $NIX_CFLAGS_COMPILE | sed -e 's/ /" --copt=\"/g')\" \\\\" \
|
|
|
|
|
-e "/\$command \\\\$/a --host_copt=\"$(echo $NIX_CFLAGS_COMPILE | sed -e 's/ /" --host_copt=\"/g')\" \\\\" \
|
|
|
|
|
-e "/\$command \\\\$/a --linkopt=\"-Wl,$(echo $NIX_LDFLAGS | sed -e 's/ /" --linkopt=\"-Wl,/g')\" \\\\" \
|
|
|
|
|
-e "/\$command \\\\$/a --host_linkopt=\"-Wl,$(echo $NIX_LDFLAGS | sed -e 's/ /" --host_linkopt=\"-Wl,/g')\" \\\\" \
|
|
|
|
|
-e "/\$command \\\\$/a --host_javabase='@local_jdk//:jdk' \\\\" \
|
|
|
|
|
-i scripts/bootstrap/compile.sh
|
2018-08-21 12:11:12 +01:00
|
|
|
|
|
|
|
|
|
# --experimental_strict_action_env (which will soon become the
|
|
|
|
|
# default, see bazelbuild/bazel#2574) hardcodes the default
|
|
|
|
|
# action environment to a value that on NixOS at least is bogus.
|
|
|
|
|
# So we hardcode it to something useful.
|
|
|
|
|
substituteInPlace \
|
|
|
|
|
src/main/java/com/google/devtools/build/lib/bazel/rules/BazelRuleClassProvider.java \
|
|
|
|
|
--replace /bin:/usr/bin ${defaultShellPath}
|
|
|
|
|
|
|
|
|
|
# append the PATH with defaultShellPath in tools/bash/runfiles/runfiles.bash
|
|
|
|
|
echo "PATH=$PATH:${defaultShellPath}" >> runfiles.bash.tmp
|
|
|
|
|
cat tools/bash/runfiles/runfiles.bash >> runfiles.bash.tmp
|
|
|
|
|
mv runfiles.bash.tmp tools/bash/runfiles/runfiles.bash
|
|
|
|
|
|
|
|
|
|
patchShebangs .
|
|
|
|
|
'';
|
|
|
|
|
in lib.optionalString stdenv.hostPlatform.isDarwin darwinPatches
|
|
|
|
|
+ genericPatches;
|
2017-02-15 15:40:27 +00:00
|
|
|
|
|
|
|
|
|
buildInputs = [
|
2018-09-10 06:12:22 +01:00
|
|
|
|
buildJdk
|
2017-09-03 12:56:21 +01:00
|
|
|
|
];
|
|
|
|
|
|
2019-01-04 17:06:39 +00:00
|
|
|
|
# when a command can’t be found in a bazel build, you might also
|
|
|
|
|
# need to add it to `defaultShellPath`.
|
2017-09-03 12:56:21 +01:00
|
|
|
|
nativeBuildInputs = [
|
2017-02-15 15:40:27 +00:00
|
|
|
|
zip
|
2017-09-03 12:56:21 +01:00
|
|
|
|
python
|
2017-02-15 15:40:27 +00:00
|
|
|
|
unzip
|
2017-02-28 17:44:44 +00:00
|
|
|
|
makeWrapper
|
2017-05-19 04:14:50 +01:00
|
|
|
|
which
|
2017-09-03 12:56:21 +01:00
|
|
|
|
customBash
|
2018-07-29 12:51:06 +01:00
|
|
|
|
] ++ lib.optionals (stdenv.isDarwin) [ cctools clang libcxx CoreFoundation CoreServices Foundation ];
|
2017-02-28 07:33:48 +00:00
|
|
|
|
|
2017-02-15 15:40:27 +00:00
|
|
|
|
# If TMPDIR is in the unpack dir we run afoul of blaze's infinite symlink
|
|
|
|
|
# detector (see com.google.devtools.build.lib.skyframe.FileFunction).
|
|
|
|
|
# Change this to $(mktemp -d) as soon as we figure out why.
|
|
|
|
|
|
|
|
|
|
buildPhase = ''
|
2018-07-14 00:10:37 +01:00
|
|
|
|
export TMPDIR=/tmp/.bazel-$UID
|
2017-02-15 15:40:27 +00:00
|
|
|
|
./compile.sh
|
2018-07-27 19:45:43 +01:00
|
|
|
|
scripts/generate_bash_completion.sh \
|
|
|
|
|
--bazel=./output/bazel \
|
|
|
|
|
--output=output/bazel-complete.bash \
|
|
|
|
|
--prepend=scripts/bazel-complete-template.bash
|
2017-02-15 15:40:27 +00:00
|
|
|
|
'';
|
|
|
|
|
|
|
|
|
|
installPhase = ''
|
|
|
|
|
mkdir -p $out/bin
|
2018-11-07 21:24:34 +00:00
|
|
|
|
|
|
|
|
|
# official wrapper scripts that searches for $WORKSPACE_ROOT/tools/bazel
|
|
|
|
|
# if it can’t find something in tools, it calls $out/bin/bazel-real
|
2018-11-05 18:42:40 +00:00
|
|
|
|
cp scripts/packages/bazel.sh $out/bin/bazel
|
|
|
|
|
mv output/bazel $out/bin/bazel-real
|
2018-11-07 21:24:34 +00:00
|
|
|
|
|
2018-12-09 14:53:26 +00:00
|
|
|
|
wrapProgram "$out/bin/bazel" --add-flags --server_javabase="${runJdk}"
|
2018-11-07 21:24:34 +00:00
|
|
|
|
|
|
|
|
|
# shell completion files
|
2017-05-19 04:14:50 +01:00
|
|
|
|
mkdir -p $out/share/bash-completion/completions $out/share/zsh/site-functions
|
2018-07-27 19:45:43 +01:00
|
|
|
|
mv output/bazel-complete.bash $out/share/bash-completion/completions/bazel
|
2017-05-19 04:14:50 +01:00
|
|
|
|
cp scripts/zsh_completion/_bazel $out/share/zsh/site-functions/
|
2017-02-15 15:40:27 +00:00
|
|
|
|
'';
|
|
|
|
|
|
2018-11-05 20:59:02 +00:00
|
|
|
|
doInstallCheck = true;
|
|
|
|
|
installCheckPhase = ''
|
|
|
|
|
export TEST_TMPDIR=$(pwd)
|
|
|
|
|
|
2018-11-07 21:24:34 +00:00
|
|
|
|
hello_test () {
|
|
|
|
|
$out/bin/bazel test --test_output=errors \
|
|
|
|
|
examples/cpp:hello-success_test \
|
|
|
|
|
examples/java-native/src/test/java/com/example/myproject:hello
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# test whether $WORKSPACE_ROOT/tools/bazel works
|
|
|
|
|
|
2018-11-05 20:59:02 +00:00
|
|
|
|
mkdir -p tools
|
2018-11-07 21:24:34 +00:00
|
|
|
|
cat > tools/bazel <<"EOF"
|
|
|
|
|
#!${stdenv.shell} -e
|
|
|
|
|
exit 1
|
|
|
|
|
EOF
|
2018-11-05 20:59:02 +00:00
|
|
|
|
chmod +x tools/bazel
|
|
|
|
|
|
2018-11-07 21:24:34 +00:00
|
|
|
|
# first call should fail if tools/bazel is used
|
|
|
|
|
! hello_test
|
2018-11-05 20:59:02 +00:00
|
|
|
|
|
2018-11-07 21:24:34 +00:00
|
|
|
|
cat > tools/bazel <<"EOF"
|
|
|
|
|
#!${stdenv.shell} -e
|
|
|
|
|
exec "$BAZEL_REAL" "$@"
|
|
|
|
|
EOF
|
2018-11-05 20:59:02 +00:00
|
|
|
|
|
2018-11-07 21:24:34 +00:00
|
|
|
|
# second call succeeds because it defers to $out/bin/bazel-real
|
|
|
|
|
hello_test
|
2018-11-05 20:59:02 +00:00
|
|
|
|
'';
|
|
|
|
|
|
2017-11-10 17:06:10 +00:00
|
|
|
|
# Save paths to hardcoded dependencies so Nix can detect them.
|
|
|
|
|
postFixup = ''
|
|
|
|
|
mkdir -p $out/nix-support
|
2019-01-22 15:42:41 +00:00
|
|
|
|
echo "${customBash} ${defaultShellPath}" >> $out/nix-support/depends
|
|
|
|
|
# The templates get tar’d up into a .jar,
|
|
|
|
|
# so nix can’t detect python is needed in the runtime closure
|
|
|
|
|
echo "${python}" >> $out/nix-support/depends
|
2017-11-10 17:06:10 +00:00
|
|
|
|
'';
|
|
|
|
|
|
2017-02-15 15:40:27 +00:00
|
|
|
|
dontStrip = true;
|
|
|
|
|
dontPatchELF = true;
|
|
|
|
|
}
|