From c7a103104b03f8a014755ee01f691f0c728ec0bb Mon Sep 17 00:00:00 2001 From: Maksim Denisov Date: Mon, 13 Jan 2025 15:06:24 +0100 Subject: Add to GitRepo common implementation IsTreeInRepo --- src/buildtool/file_system/git_repo.cpp | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) (limited to 'src/buildtool/file_system/git_repo.cpp') diff --git a/src/buildtool/file_system/git_repo.cpp b/src/buildtool/file_system/git_repo.cpp index 78ae1c86..2c27cda9 100644 --- a/src/buildtool/file_system/git_repo.cpp +++ b/src/buildtool/file_system/git_repo.cpp @@ -1744,6 +1744,35 @@ auto GitRepo::ImportToGit( return *std::move(result_tree); } +auto GitRepo::IsTreeInRepo(std::filesystem::path const& repo, + std::string const& tree_id) noexcept + -> expected { + auto git_cas = GitCAS::Open(repo); + if (git_cas == nullptr) { + return unexpected( + fmt::format("Failed to open Git ODB at {}", repo.string())); + } + auto git_repo = GitRepo::Open(git_cas); + if (not git_repo.has_value()) { + return unexpected{ + fmt::format("Failed to open Git repository at {}", repo.string())}; + } + + std::string err; + auto logger = std::make_shared( + [&err](auto const& msg, bool fatal) { + if (fatal) { + err = msg; + } + }); + + auto result = git_repo->CheckTreeExists(tree_id, logger); + if (not result.has_value()) { + return unexpected{std::move(err)}; + } + return *result; +} + auto GitRepo::IsRepoFake() const noexcept -> bool { return is_repo_fake_; } -- cgit v1.2.3