From 665b1b04f255ef27403d67d4a4ca8582c179307b Mon Sep 17 00:00:00 2001 From: Klaus Aehlig Date: Tue, 16 Jan 2024 16:57:16 +0100 Subject: TargetCacheEntry: serialize implied export targets --- src/buildtool/storage/target_cache_entry.cpp | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) (limited to 'src') diff --git a/src/buildtool/storage/target_cache_entry.cpp b/src/buildtool/storage/target_cache_entry.cpp index 002b3465..2f245624 100644 --- a/src/buildtool/storage/target_cache_entry.cpp +++ b/src/buildtool/storage/target_cache_entry.cpp @@ -17,6 +17,8 @@ #include #include #include +#include +#include #include "src/buildtool/logging/log_level.hpp" #include "src/buildtool/logging/logger.hpp" @@ -29,10 +31,18 @@ auto TargetCacheEntry::FromTarget( auto result = TargetResult{.artifact_stage = target->Artifacts(), .provides = target->Provides(), .runfiles = target->RunFiles()}; - if (auto desc = result.ReplaceNonKnownAndToJson(replacements)) { - return TargetCacheEntry{*desc}; + auto desc = result.ReplaceNonKnownAndToJson(replacements); + if (not desc) { + return std::nullopt; } - return std::nullopt; + std::vector implied{}; + for (auto const& x : target->ImpliedExport()) { + implied.emplace_back(x); + } + if (not implied.empty()) { + (*desc)["implied export targets"] = implied; + } + return TargetCacheEntry{*desc}; } auto TargetCacheEntry::FromJson(nlohmann::json desc) noexcept -- cgit v1.2.3