From bb2375008f69bf62d510ce862f1d4370fa130ef3 Mon Sep 17 00:00:00 2001 From: Sascha Roloff Date: Fri, 8 Jul 2022 10:04:34 +0200 Subject: Introduced batch availability check for remote execution api --- .../execution_api/remote/bazel/bazel_api.cpp | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) (limited to 'src/buildtool/execution_api/remote/bazel/bazel_api.cpp') diff --git a/src/buildtool/execution_api/remote/bazel/bazel_api.cpp b/src/buildtool/execution_api/remote/bazel/bazel_api.cpp index ca5d4946..51e85176 100644 --- a/src/buildtool/execution_api/remote/bazel/bazel_api.cpp +++ b/src/buildtool/execution_api/remote/bazel/bazel_api.cpp @@ -170,7 +170,7 @@ auto BazelApi::CreateAction( return std::nullopt; } if (tree_map_->AddTree(*digest, std::move(tree))) { - return ArtifactDigest{std::move(*digest)}; + return ArtifactDigest{*digest}; } return std::nullopt; } @@ -179,3 +179,23 @@ auto BazelApi::CreateAction( ArtifactDigest const& digest) const noexcept -> bool { return network_->IsAvailable(digest); } + +[[nodiscard]] auto BazelApi::IsAvailable( + std::vector const& digests) const noexcept + -> std::vector { + std::vector bazel_digests; + bazel_digests.reserve(digests.size()); + std::transform(digests.begin(), + digests.end(), + std::back_inserter(bazel_digests), + [](ArtifactDigest const& digest) { return digest; }); + auto bazel_result = network_->IsAvailable(bazel_digests); + std::vector result; + result.reserve(bazel_result.size()); + std::transform( + bazel_result.begin(), + bazel_result.end(), + std::back_inserter(result), + [](bazel_re::Digest& digest) { return ArtifactDigest{digest}; }); + return result; +} -- cgit v1.2.3