From 8d77b24503fcddce8f79f138cf07be5ad7eb8473 Mon Sep 17 00:00:00 2001 From: Klaus Aehlig Date: Tue, 13 Jun 2023 10:14:33 +0200 Subject: action data structure: support (additional) execution properties --- src/buildtool/build_engine/target_map/utils.cpp | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'src/buildtool/build_engine/target_map/utils.cpp') diff --git a/src/buildtool/build_engine/target_map/utils.cpp b/src/buildtool/build_engine/target_map/utils.cpp index c0932dc9..55543e30 100644 --- a/src/buildtool/build_engine/target_map/utils.cpp +++ b/src/buildtool/build_engine/target_map/utils.cpp @@ -196,6 +196,7 @@ auto BuildMaps::Target::Utils::createAction( std::optional may_fail, bool no_cache, double timeout_scale, + const ExpressionPtr& execution_properties_exp, const ExpressionPtr& inputs_exp) -> ActionDescription::Ptr { auto hasher = HashFunction::Hasher(); hasher.Update(hash_vector(output_files)); @@ -206,6 +207,7 @@ auto BuildMaps::Target::Utils::createAction( : std::vector{})); hasher.Update(no_cache ? std::string{"N"} : std::string{"Y"}); hasher.Update(fmt::format("{:+24a}", timeout_scale)); + hasher.Update(execution_properties_exp->ToHash()); hasher.Update(inputs_exp->ToHash()); auto action_id = std::move(hasher).Finalize().HexString(); @@ -214,6 +216,11 @@ auto BuildMaps::Target::Utils::createAction( for (auto const& [env_var, env_value] : env->Map()) { env_vars.emplace(env_var, env_value->String()); } + std::map execution_properties{}; + for (auto const& [prop_name, prop_value] : + execution_properties_exp->Map()) { + execution_properties.emplace(prop_name, prop_value->String()); + } ActionDescription::inputs_t inputs; inputs.reserve(inputs_exp->Map().size()); for (auto const& [input_path, artifact] : inputs_exp->Map()) { @@ -226,6 +233,7 @@ auto BuildMaps::Target::Utils::createAction( std::move(env_vars), std::move(may_fail), no_cache, - timeout_scale}, + timeout_scale, + execution_properties}, std::move(inputs)); } -- cgit v1.2.3