From 92c7781ba17ae53c491214565d317b87f911d573 Mon Sep 17 00:00:00 2001 From: "Standing-StormStanding-Storm git config --global user.name Standing-Storm git config --global user.name Standing-Storm" Date: Wed, 25 Dec 2024 17:06:20 -0600 Subject: [PATCH] Initial commit --- .../effectoncondition/eoc_misc.json | 19 ++++++++- .../eoc_on_power_use_events.json | 40 ++++++++++++------- doc/EFFECT_ON_CONDITION.md | 2 +- src/creature.cpp | 2 +- src/event.h | 3 +- 5 files changed, 47 insertions(+), 19 deletions(-) diff --git a/data/mods/MindOverMatter/effectoncondition/eoc_misc.json b/data/mods/MindOverMatter/effectoncondition/eoc_misc.json index 580c49a235f52..5ea7558572b77 100644 --- a/data/mods/MindOverMatter/effectoncondition/eoc_misc.json +++ b/data/mods/MindOverMatter/effectoncondition/eoc_misc.json @@ -183,13 +183,28 @@ { "compare_string": [ "dazed", { "context_val": "effect" } ] }, { "compare_string": [ "psi_dazed", { "context_val": "effect" } ] }, { "compare_string": [ "psi_dazed_zap", { "context_val": "effect" } ] }, - { "compare_string": [ "downed", { "context_val": "effect" } ] } + { "compare_string": [ "downed", { "context_val": "effect" } ] }, + { + "and": [ + { "compare_string": [ "effect_disease_psionic_drain", { "context_val": "effect" } ] }, + { "math": [ "_intensity == 5" ] } + ] + }, + { + "and": [ + { "compare_string": [ "effect_disease_psionic_drain", { "context_val": "effect" } ] }, + { "math": [ "_intensity == 11" ] } + ] + } ] }, { "math": [ "u_vitamin('vitamin_maintained_powers') >= 1" ] } ] }, - "effect": [ { "run_eocs": [ "EOC_POWER_MAINTENANCE_CONCENTRATION_CHECK" ] } ] + "effect": [ + { "message": "This is proof that the EoC works right." }, + { "run_eocs": [ "EOC_POWER_MAINTENANCE_CONCENTRATION_CHECK" ] } + ] }, { "type": "effect_on_condition", diff --git a/data/mods/MindOverMatter/effectoncondition/eoc_on_power_use_events.json b/data/mods/MindOverMatter/effectoncondition/eoc_on_power_use_events.json index 00f4b032f17d9..cb826408e60f8 100644 --- a/data/mods/MindOverMatter/effectoncondition/eoc_on_power_use_events.json +++ b/data/mods/MindOverMatter/effectoncondition/eoc_on_power_use_events.json @@ -555,27 +555,39 @@ { "type": "effect_on_condition", "id": "EOC_POWER_MAINTENANCE_PLUS_ONE", - "condition": { "math": [ "u_vitamin('vitamin_maintained_powers') >= concentration_calculations()" ] }, "effect": [ - { - "u_message": "It's taking you a lot of concentration to maintain your powers. You're not sure you'll be able to do it for very long.", - "type": "bad" - }, - { "u_add_effect": "effect_psi_intense_concentration", "duration": "PERMANENT" }, - { "math": [ "u_vitamin('vitamin_maintained_powers')", "+=", "1" ] } - ], - "false_effect": [ { "math": [ "u_vitamin('vitamin_maintained_powers')", "+=", "1" ] } ] + { "math": [ "u_vitamin('vitamin_maintained_powers')", "+=", "1" ] }, + { "run_eocs": "EOC_CONCENTRATION_VS_LIMIT_CALCULATIONS" } + ] }, { "type": "effect_on_condition", "id": "EOC_POWER_MAINTENANCE_MINUS_ONE", - "condition": { "math": [ "u_vitamin('vitamin_maintained_powers') == concentration_calculations() + 1" ] }, "effect": [ - { "u_message": "As you stop concentrating, your mind clears a bit. It's easier to think now.", "type": "good" }, - { "u_lose_effect": "effect_psi_intense_concentration" }, - { "math": [ "u_vitamin('vitamin_maintained_powers')", "-=", "1" ] } + { "math": [ "u_vitamin('vitamin_maintained_powers')", "-=", "1" ] }, + { "run_eocs": "EOC_CONCENTRATION_VS_LIMIT_CALCULATIONS" } + ] + }, + { + "type": "effect_on_condition", + "id": "EOC_CONCENTRATION_VS_LIMIT_CALCULATIONS", + "condition": { "math": [ "u_vitamin('vitamin_maintained_powers') > concentration_calculations()" ] }, + "effect": [ + { + "u_message": "It's taking you a lot of concentration to maintain your powers. You're not sure you'll be able to do it for very long.", + "type": "bad" + }, + { "u_add_effect": "effect_psi_intense_concentration", "duration": "PERMANENT" } ], - "false_effect": [ { "math": [ "u_vitamin('vitamin_maintained_powers')", "-=", "1" ] } ] + "false_effect": [ + { + "if": { "u_has_effect": "effect_psi_intense_concentration" }, + "then": [ + { "u_message": "As you stop concentrating, your mind clears a bit. It's easier to think now.", "type": "good" }, + { "u_lose_effect": "effect_psi_intense_concentration" } + ] + } + ] }, { "type": "effect_on_condition", diff --git a/doc/EFFECT_ON_CONDITION.md b/doc/EFFECT_ON_CONDITION.md index 91659547f023f..0cbdce03795bf 100644 --- a/doc/EFFECT_ON_CONDITION.md +++ b/doc/EFFECT_ON_CONDITION.md @@ -1479,7 +1479,7 @@ Every event EOC passes context vars with each of their key value pairs that the | character_eats_item | | { "character", `character_id` },
{ "itype", `itype_id` }, | character / NONE | | character_finished_activity | Triggered when character finished or canceled activity | { "character", `character_id` },
{ "activity", `activity_id` },
{ "canceled", `bool` } | character / NONE | | character_forgets_spell | | { "character", `character_id` },
{ "spell", `spell_id` } | character / NONE | -| character_gains_effect | | { "character", `character_id` },
{ "effect", `efftype_id` },
{ "bodypart", `bodypart_id` } | character / NONE | +| character_gains_effect | | { "character", `character_id` },
{ "effect", `efftype_id` },
{ "bodypart", `bodypart_id` }, { "intensity", `int` }
| character / NONE | | character_gets_headshot | | { "character", `character_id` } | character / NONE | | character_heals_damage | | { "character", `character_id` },
{ "damage", `int` }, | character / NONE | | character_kills_character | | { "killer", `character_id` },
{ "victim", `character_id` },
{ "victim_name", `string` }, | character / NONE | diff --git a/src/creature.cpp b/src/creature.cpp index ccab04ac3b078..0df64c45c5750 100644 --- a/src/creature.cpp +++ b/src/creature.cpp @@ -1798,7 +1798,7 @@ void Creature::add_effect( const effect_source &source, const efftype_id &eff_id } ( *effects )[eff_id][bp] = e; if( Character *ch = as_character() ) { - get_event_bus().send( ch->getID(), bp.id(), eff_id ); + get_event_bus().send( ch->getID(), bp.id(), eff_id, intensity ); if( is_avatar() ) { eff_id->add_apply_msg( e.get_intensity() ); } diff --git a/src/event.h b/src/event.h index 646ca0f4a2696..a6b024c3be714 100644 --- a/src/event.h +++ b/src/event.h @@ -339,10 +339,11 @@ struct event_spec { template<> struct event_spec { - static constexpr std::array, 3> fields = {{ + static constexpr std::array, 4> fields = {{ { "character", cata_variant_type::character_id }, { "bodypart", cata_variant_type::body_part}, { "effect", cata_variant_type::efftype_id }, + { "intensity", cata_variant_type::int_ } } }; };