bazel-remote: 1.0.0 -> 2.0.1
This commit is contained in:
parent
0776eae5ae
commit
a975c80f91
@ -1,85 +1,22 @@
|
|||||||
{ buildBazelPackage
|
{ buildGoModule
|
||||||
, cacert
|
|
||||||
, fetchFromGitHub
|
, fetchFromGitHub
|
||||||
, git
|
|
||||||
, go
|
|
||||||
, lib
|
, lib
|
||||||
, stdenv
|
|
||||||
}:
|
}:
|
||||||
|
|
||||||
buildBazelPackage rec {
|
buildGoModule rec {
|
||||||
pname = "bazel-remote";
|
pname = "bazel-remote";
|
||||||
version = "1.0.0";
|
version = "2.0.1";
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
src = fetchFromGitHub {
|
||||||
owner = "buchgr";
|
owner = "buchgr";
|
||||||
repo = "bazel-remote";
|
repo = pname;
|
||||||
rev = "v${version}";
|
rev = "v${version}";
|
||||||
sha256 = "1fpdw139d5q1377qnqbgkahmdr4mdaa17d2m10wkyvyvijwm4r2m";
|
sha256 = "193amcx4nk7mr51jcawym46gizqmfkvksjxm64pf7s3wraf00v01";
|
||||||
};
|
};
|
||||||
|
|
||||||
nativeBuildInputs = [ go git ];
|
vendorSha256 = "1sxv9mya8plkn3hpjgfpzgwlh4m3cbhpywqv86brj2h9i4ad0gl5";
|
||||||
|
|
||||||
bazelTarget = "//:bazel-remote";
|
doCheck = false;
|
||||||
|
|
||||||
removeRulesCC = false;
|
|
||||||
|
|
||||||
# this is to work around `test -f` failing when called by gazelle
|
|
||||||
# https://github.com/bazelbuild/bazel-gazelle/blob/v0.19.1/internal/go_repository.bzl#L135
|
|
||||||
patches = [ ./disable_build_file_generation.patch ];
|
|
||||||
|
|
||||||
fetchAttrs = {
|
|
||||||
preBuild = ''
|
|
||||||
patchShebangs .
|
|
||||||
|
|
||||||
# tell rules_go to use the Go binary found in the PATH
|
|
||||||
sed -e 's:go_register_toolchains():go_register_toolchains(go_version = "host"):g' -i WORKSPACE
|
|
||||||
|
|
||||||
# tell rules_go to invoke GIT with custom CAINFO path
|
|
||||||
export GIT_SSL_CAINFO="${cacert}/etc/ssl/certs/ca-bundle.crt"
|
|
||||||
|
|
||||||
# force gazelle to use the nix go cache rather than its own
|
|
||||||
# export GO_REPOSITORY_USE_HOST_CACHE=1
|
|
||||||
'';
|
|
||||||
|
|
||||||
preInstall = ''
|
|
||||||
# Remove the go_sdk (it's just a copy of the go derivation) and all
|
|
||||||
# references to it from the marker files. Bazel does not need to download
|
|
||||||
# this sdk because we have patched the WORKSPACE file to point to the one
|
|
||||||
# currently present in PATH. Without removing the go_sdk from the marker
|
|
||||||
# file, the hash of it will change anytime the Go derivation changes and
|
|
||||||
# that would lead to impurities in the marker files which would result in
|
|
||||||
# a different sha256 for the fetch phase.
|
|
||||||
rm -rf $bazelOut/external/{go_sdk,\@go_sdk.marker}
|
|
||||||
sed -e '/^FILE:@go_sdk.*/d' -i $bazelOut/external/\@*.marker
|
|
||||||
|
|
||||||
# Remove the gazelle repository cache as it contains built binaries
|
|
||||||
chmod -R u+w $bazelOut/external/bazel_gazelle_go_repository_cache
|
|
||||||
rm -rf $bazelOut/external/{bazel_gazelle_go_repository_cache,\@bazel_gazelle_go_repository_cache.marker}
|
|
||||||
sed -e '/^FILE:@bazel_gazelle_go_repository_cache.*/d' -i $bazelOut/external/\@*.marker
|
|
||||||
|
|
||||||
# Remove the gazelle tools, they contain go binaries that are built
|
|
||||||
# non-deterministically. As long as the gazelle version matches the tools
|
|
||||||
# should be equivalent.
|
|
||||||
rm -rf $bazelOut/external/{bazel_gazelle_go_repository_tools,\@bazel_gazelle_go_repository_tools.marker}
|
|
||||||
sed -e '/^FILE:@bazel_gazelle_go_repository_tools.*/d' -i $bazelOut/external/\@*.marker
|
|
||||||
'';
|
|
||||||
|
|
||||||
sha256 = "1vijh3nl30n8k6xlx6in92pzs70x15akbqiqalk8apgvphvdz8vy";
|
|
||||||
};
|
|
||||||
|
|
||||||
buildAttrs = {
|
|
||||||
preBuild = ''
|
|
||||||
patchShebangs .
|
|
||||||
|
|
||||||
# tell rules_go to use the Go binary found in the PATH
|
|
||||||
sed -e 's:go_register_toolchains():go_register_toolchains(go_version = "host"):g' -i WORKSPACE
|
|
||||||
'';
|
|
||||||
|
|
||||||
installPhase = ''
|
|
||||||
install -Dm755 bazel-bin/*_pure_stripped/bazel-remote $out/bin/bazel-remote
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
meta = with lib; {
|
meta = with lib; {
|
||||||
homepage = "https://github.com/buchgr/bazel-remote";
|
homepage = "https://github.com/buchgr/bazel-remote";
|
||||||
@ -87,6 +24,5 @@ buildBazelPackage rec {
|
|||||||
license = licenses.asl20;
|
license = licenses.asl20;
|
||||||
maintainers = [ maintainers.uri-canva ];
|
maintainers = [ maintainers.uri-canva ];
|
||||||
platforms = platforms.darwin ++ platforms.linux;
|
platforms = platforms.darwin ++ platforms.linux;
|
||||||
broken = stdenv.isDarwin;
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user