From 6e2ff90f698d327ff8ed7c3943166a3ad5f9b278 Mon Sep 17 00:00:00 2001 From: Klaus Aehlig Date: Mon, 4 Mar 2024 15:51:12 +0100 Subject: serve client: add custom function to ask for a foreign-file root --- .../serve_api/remote/source_tree_client.cpp | 31 ++++++++++++++++++++++ 1 file changed, 31 insertions(+) (limited to 'src/buildtool/serve_api/remote/source_tree_client.cpp') diff --git a/src/buildtool/serve_api/remote/source_tree_client.cpp b/src/buildtool/serve_api/remote/source_tree_client.cpp index 0cb93a36..b7bfcecb 100644 --- a/src/buildtool/serve_api/remote/source_tree_client.cpp +++ b/src/buildtool/serve_api/remote/source_tree_client.cpp @@ -157,6 +157,37 @@ auto SourceTreeClient::ServeDistdirTree( return response.tree(); // success } +auto SourceTreeClient::ServeForeignFileTree(const std::string& content, + const std::string& name, + bool executable) noexcept + -> result_t { + justbuild::just_serve::ServeDistdirTreeRequest request{}; + auto* distfile = request.add_distfiles(); + distfile->set_name(name); + distfile->set_content(content); + distfile->set_executable(executable); + + grpc::ClientContext context; + justbuild::just_serve::ServeDistdirTreeResponse response; + grpc::Status status = stub_->ServeDistdirTree(&context, request, &response); + + if (not status.ok()) { + LogStatus(&logger_, LogLevel::Debug, status); + return true; // fatal failure + } + if (response.status() != + ::justbuild::just_serve::ServeDistdirTreeResponse::OK) { + logger_.Emit(LogLevel::Debug, + "ServeDistdirTree called for foreign file response " + "returned with {}", + static_cast(response.status())); + return /*fatal = */ ( + response.status() != + ::justbuild::just_serve::ServeDistdirTreeResponse::NOT_FOUND); + } + return response.tree(); // success +} + auto SourceTreeClient::ServeContent(std::string const& content) noexcept -> bool { justbuild::just_serve::ServeContentRequest request{}; -- cgit v1.2.3