aboutsummaryrefslogtreecommitdiff
path: root/src/openvic-simulation/economy/GoodDefinition.cpp
diff options
context:
space:
mode:
author hop311 <hop3114@gmail.com>2024-09-19 00:07:28 +0200
committer hop311 <hop3114@gmail.com>2024-09-19 00:07:28 +0200
commit5550b237fa9b6f8c6a86eea0de9d32e28a626dc7 (patch)
treeed4e867e2c099b027da2e2205b99575edae7b561 /src/openvic-simulation/economy/GoodDefinition.cpp
parentf0814926f675d6ecf889d8add410b1c37f625b29 (diff)
ModifierEffect and Rule localisation keysrule-modifier-locale-keys
Diffstat (limited to 'src/openvic-simulation/economy/GoodDefinition.cpp')
-rw-r--r--src/openvic-simulation/economy/GoodDefinition.cpp41
1 files changed, 29 insertions, 12 deletions
diff --git a/src/openvic-simulation/economy/GoodDefinition.cpp b/src/openvic-simulation/economy/GoodDefinition.cpp
index f21ea18..82d3719 100644
--- a/src/openvic-simulation/economy/GoodDefinition.cpp
+++ b/src/openvic-simulation/economy/GoodDefinition.cpp
@@ -88,29 +88,46 @@ bool GoodDefinitionManager::load_goods_file(ast::NodeCPtr root) {
}
bool GoodDefinitionManager::generate_modifiers(ModifierManager& modifier_manager) const {
+ using enum ModifierEffect::format_t;
+
bool ret = true;
- const auto good_modifier = [this, &modifier_manager, &ret](std::string_view name, bool is_positive_good) -> void {
+ const auto good_modifier = [this, &modifier_manager, &ret](
+ std::string_view name, bool is_positive_good, auto make_localisation_suffix
+ ) -> void {
ret &= modifier_manager.register_complex_modifier(name);
+
for (GoodDefinition const& good : get_good_definitions()) {
ret &= modifier_manager.add_modifier_effect(
- ModifierManager::get_flat_identifier(name, good.get_identifier()), is_positive_good
+ ModifierManager::get_flat_identifier(name, good.get_identifier()), is_positive_good, PROPORTION_DECIMAL,
+ make_localisation_suffix(good.get_identifier())
);
}
};
- good_modifier("artisan_goods_input", false);
- good_modifier("artisan_goods_output", true);
- good_modifier("artisan_goods_throughput", true);
- good_modifier("factory_goods_input", false);
- good_modifier("factory_goods_output", true);
- good_modifier("factory_goods_throughput", true);
- good_modifier("rgo_goods_output", true);
- good_modifier("rgo_goods_throughput", true);
- good_modifier("rgo_size", true);
+ const auto make_production_localisation_suffix = [](std::string_view localisation_suffix) -> auto {
+ return [localisation_suffix](std::string_view good_identifier) -> std::string {
+ return StringUtils::append_string_views("$", good_identifier, "$ $", localisation_suffix, "$");
+ };
+ };
+
+ good_modifier("artisan_goods_input", false, make_production_localisation_suffix("TECH_INPUT"));
+ good_modifier("artisan_goods_output", true, make_production_localisation_suffix("TECH_OUTPUT"));
+ good_modifier("artisan_goods_throughput", true, make_production_localisation_suffix("TECH_THROUGHPUT"));
+ good_modifier("factory_goods_input", false, make_production_localisation_suffix("TECH_INPUT"));
+ good_modifier("factory_goods_output", true, make_production_localisation_suffix("TECH_OUTPUT"));
+ good_modifier("factory_goods_throughput", true, make_production_localisation_suffix("TECH_THROUGHPUT"));
+ good_modifier("rgo_goods_output", true, make_production_localisation_suffix("TECH_OUTPUT"));
+ good_modifier("rgo_goods_throughput", true, make_production_localisation_suffix("TECH_THROUGHPUT"));
+ good_modifier("rgo_size", true, [](std::string_view good_identifier) -> std::string {
+ return StringUtils::append_string_views(good_identifier, "_RGO_SIZE");
+ });
for (GoodDefinition const& good : get_good_definitions()) {
- ret &= modifier_manager.add_modifier_effect(good.get_identifier(), true, ModifierEffect::format_t::PERCENTAGE_DECIMAL);
+ ret &= modifier_manager.add_modifier_effect(
+ good.get_identifier(), true, PERCENTAGE_DECIMAL,
+ StringUtils::append_string_views("$ENCOURAGEMENT_FOR$$", good.get_identifier(), "$")
+ );
}
return ret;