diff --git a/data/json/effects_on_condition/npc_eocs/isherwood_barry_rescue_eocs.json b/data/json/effects_on_condition/npc_eocs/isherwood_barry_rescue_eocs.json index 63dd374a69c87..01be976467685 100644 --- a/data/json/effects_on_condition/npc_eocs/isherwood_barry_rescue_eocs.json +++ b/data/json/effects_on_condition/npc_eocs/isherwood_barry_rescue_eocs.json @@ -475,7 +475,8 @@ }, { "type": "effect_on_condition", - "eoc_type": "OM_MOVE", + "eoc_type": "EVENT", + "required_event": "avatar_enters_omt", "id": "EOC_HAVE_U_BEEN_TO_MIGOS", "condition": { "or": [ diff --git a/doc/EFFECT_ON_CONDITION.md b/doc/EFFECT_ON_CONDITION.md index effe943855299..9aebac18582fa 100644 --- a/doc/EFFECT_ON_CONDITION.md +++ b/doc/EFFECT_ON_CONDITION.md @@ -38,7 +38,7 @@ An effect_on_condition is an object allowing the combination of dialog condition | `false_effect` | effect | The effect(s) caused if `condition` returns false upon activation. See the "Dialogue Effects" section of [NPCs](NPCs.md) for the full syntax. | `global` | bool | If this is true, this recurring eoc will be run on the player and every npc from a global queue. Deactivate conditions will work based on the avatar. If it is false the avatar and every character will have their own copy and their own deactivated list. Defaults to false. | `run_for_npcs` | bool | Can only be true if global is true. If false the EOC will only be run against the avatar. If true the eoc will be run against the avatar and all npcs. Defaults to false. -| `EOC_TYPE` | string | Can be one of `ACTIVATION`, `RECURRING`, `SCENARIO_SPECIFIC`, `AVATAR_DEATH`, `NPC_DEATH`, `OM_MOVE`, `PREVENT_DEATH`, `EVENT` (see details below). It defaults to `ACTIVATION` unless `recurrence` is provided in which case it defaults to `RECURRING`. +| `EOC_TYPE` | string | Can be one of `ACTIVATION`, `RECURRING`, `SCENARIO_SPECIFIC`, `AVATAR_DEATH`, `NPC_DEATH`, `PREVENT_DEATH`, `EVENT` (see details below). It defaults to `ACTIVATION` unless `recurrence` is provided in which case it defaults to `RECURRING`. ### EOC types @@ -49,7 +49,6 @@ An effect_on_condition is an object allowing the combination of dialog condition * `SCENARIO_SPECIFIC` - automatically invoked once on scenario start. * `AVATAR_DEATH` - automatically invoked whenever the current avatar dies (it will be run with the avatar as `u`), if after it the player is no longer dead they will not die, if there are multiple EOCs they all be run until the player is not dead. * `NPC_DEATH` - EOCs can only be assigned to run on the death of an npc, in which case u will be the dying npc and npc will be the killer. If after it npc is no longer dead they will not die, if there are multiple they all be run until npc is not dead. -* `OM_MOVE` - EOCs trigger when the player moves overmap tiles * `PREVENT_DEATH` - whenever the current avatar dies it will be run with the avatar as `u`, if after it the player is no longer dead they will not die, if there are multiple they all be run until the player is not dead. * `EVENT` - EOCs trigger when a specific event given by "required_event" takes place. diff --git a/src/effect_on_condition.cpp b/src/effect_on_condition.cpp index 0084c75df6171..e0b13687b9bd2 100644 --- a/src/effect_on_condition.cpp +++ b/src/effect_on_condition.cpp @@ -42,7 +42,6 @@ namespace io case eoc_type::SCENARIO_SPECIFIC: return "SCENARIO_SPECIFIC"; case eoc_type::AVATAR_DEATH: return "AVATAR_DEATH"; case eoc_type::NPC_DEATH: return "NPC_DEATH"; - case eoc_type::OM_MOVE: return "OM_MOVE"; case eoc_type::PREVENT_DEATH: return "PREVENT_DEATH"; case eoc_type::EVENT: return "EVENT"; case eoc_type::NUM_EOC_TYPES: break; @@ -467,17 +466,6 @@ void effect_on_conditions::avatar_death() } } -void effect_on_conditions::om_move() -{ - avatar &player_character = get_avatar(); - dialogue d( get_talker_for( player_character ), nullptr ); - for( const effect_on_condition &eoc : effect_on_conditions::get_all() ) { - if( eoc.type == eoc_type::OM_MOVE ) { - eoc.activate( d ); - } - } -} - void effect_on_condition::finalize() { } diff --git a/src/effect_on_condition.h b/src/effect_on_condition.h index 0ac5b68bc268f..c3b974928e45f 100644 --- a/src/effect_on_condition.h +++ b/src/effect_on_condition.h @@ -32,7 +32,6 @@ enum eoc_type { SCENARIO_SPECIFIC, AVATAR_DEATH, NPC_DEATH, - OM_MOVE, PREVENT_DEATH, EVENT, NUM_EOC_TYPES @@ -114,8 +113,6 @@ void write_global_eocs_to_file(); void prevent_death(); /** Run all avatar death eocs */ void avatar_death(); -/** Run all OM_MOVE eocs */ -void om_move(); } // namespace effect_on_conditions template<> diff --git a/src/game.cpp b/src/game.cpp index 281f50c59a667..813cfcf0ddba0 100644 --- a/src/game.cpp +++ b/src/game.cpp @@ -13927,7 +13927,6 @@ void avatar_moves( const tripoint &old_abs_pos, const avatar &u, const map &m ) const oter_id &past_ter = overmap_buffer.ter( old_abs_omt ); get_event_bus().send( new_abs_omt.raw(), cur_ter ); // if the player has moved omt then might trigger an EOC for that OMT - effect_on_conditions::om_move(); if( !past_ter->get_exit_EOC().is_null() ) { dialogue d( get_talker_for( get_avatar() ), nullptr ); effect_on_condition_id eoc = cur_ter->get_exit_EOC();