diff --git a/src/activity_handlers.cpp b/src/activity_handlers.cpp index ba6bc17132df3..a801bf9f441c4 100644 --- a/src/activity_handlers.cpp +++ b/src/activity_handlers.cpp @@ -1983,7 +1983,7 @@ void activity_handlers::start_fire_do_turn( player_activity *act, Character *you you->mod_moves( -you->get_moves() ); const firestarter_actor *actor = dynamic_cast( usef->get_actor_ptr() ); - const float light = actor->light_mod( you->pos() ); + const float light = actor->light_mod( you->pos_bub() ); act->moves_left -= light * 100; if( light < 0.1 ) { add_msg( m_bad, _( "There is not enough sunlight to start a fire now. You stop trying." ) ); diff --git a/src/avatar.cpp b/src/avatar.cpp index 365b9b7e2b906..280a9c92b0f5b 100644 --- a/src/avatar.cpp +++ b/src/avatar.cpp @@ -434,7 +434,7 @@ bool avatar::read( item_location &book, item_location ereader ) // spells are handled in a different place // src/iuse_actor.cpp -> learn_spell_actor::use if( book->get_use( "learn_spell" ) ) { - book->get_use( "learn_spell" )->call( this, *book, pos() ); + book->get_use( "learn_spell" )->call( this, *book, pos_bub() ); return true; } @@ -1488,7 +1488,7 @@ bool avatar::invoke_item( item *used, const tripoint_bub_ms &pt, int pre_obtain_ umenu.hilight_disabled = true; for( const auto &e : use_methods ) { - const auto res = e.second.can_call( *this, *used, pt.raw() ); + const auto res = e.second.can_call( *this, *used, pt ); umenu.addentry_desc( MENU_AUTOASSIGN, res.success(), MENU_AUTOASSIGN, e.second.get_name(), res.str() ); } diff --git a/src/character.cpp b/src/character.cpp index 45c4dbb0f9a7c..256eb764d17c0 100644 --- a/src/character.cpp +++ b/src/character.cpp @@ -9692,7 +9692,7 @@ item Character::find_firestarter_with_charges( const int quantity ) const const use_function *usef = it.type->get_use( "firestarter" ); if( usef != nullptr && usef->get_actor_ptr() != nullptr ) { const firestarter_actor *actor = dynamic_cast( usef->get_actor_ptr() ); - if( actor->can_use( *this->as_character(), it, tripoint::zero ).success() ) { + if( actor->can_use( *this->as_character(), it, tripoint_bub_ms::zero ).success() ) { ret = it; return true; } diff --git a/src/construction.cpp b/src/construction.cpp index a8b175c4bdace..5548b9d2aa523 100644 --- a/src/construction.cpp +++ b/src/construction.cpp @@ -1664,9 +1664,8 @@ void construct::done_grave( const tripoint_bub_ms &p, Character &player_characte } } if( player_character.has_quality( qual_CUT ) ) { - // TODO: fix point types iuse::handle_ground_graffiti( player_character, nullptr, _( "Inscribe something on the grave?" ), - p.raw() ); + p ); } else { add_msg( m_neutral, _( "Unfortunately you don't have anything sharp to place an inscription on the grave." ) ); diff --git a/src/game.cpp b/src/game.cpp index 16b2310cac168..15294483e9606 100644 --- a/src/game.cpp +++ b/src/game.cpp @@ -3083,7 +3083,7 @@ void game::move_save_to_graveyard() debugmsg( "could not find save files in '%s'", save_dir ); } - for( const auto &src_path : save_files ) { + for( const cata_path &src_path : save_files ) { const cata_path dst_path = graveyard_dir / src_path.get_relative_path().filename(); if( rename_file( src_path, dst_path ) ) { @@ -8183,7 +8183,7 @@ bool game::take_screenshot() const timestamp_now() ); std::string file_name = ensure_valid_file_name( tmp_file_name ); - auto current_file_path = map_directory / file_name; + cata_path current_file_path = map_directory / file_name; // Take a screenshot of the viewport. if( take_screenshot( current_file_path.generic_u8string() ) ) { diff --git a/src/game_inventory.cpp b/src/game_inventory.cpp index 9f9c99fe095ab..1062f9d0e6345 100644 --- a/src/game_inventory.cpp +++ b/src/game_inventory.cpp @@ -1136,7 +1136,7 @@ class activatable_inventory_preset : public pickup_inventory_preset } if( uses.size() == 1 ) { - const auto ret = uses.begin()->second.can_call( you, it, you.pos() ); + const auto ret = uses.begin()->second.can_call( you, it, you.pos_bub() ); if( !ret.success() ) { return trim_trailing_punctuations( ret.str() ); } diff --git a/src/handle_action.cpp b/src/handle_action.cpp index dd18198ec3504..8fab8fda01fda 100644 --- a/src/handle_action.cpp +++ b/src/handle_action.cpp @@ -1715,7 +1715,7 @@ static void read() item the_book = *loc.get_item(); if( avatar_action::check_stealing( get_player_character(), the_book ) ) { if( loc->type->can_use( "learn_spell" ) ) { - the_book.get_use( "learn_spell" )->call( &player_character, the_book, player_character.pos() ); + the_book.get_use( "learn_spell" )->call( &player_character, the_book, player_character.pos_bub() ); } else { loc = loc.obtain( player_character ); player_character.read( loc ); diff --git a/src/iexamine.cpp b/src/iexamine.cpp index 443f9d4496ba5..f8f974ffd5a20 100644 --- a/src/iexamine.cpp +++ b/src/iexamine.cpp @@ -1918,7 +1918,7 @@ void iexamine::locked_object( Character &you, const tripoint_bub_ms &examp ) //~ %1$s: terrain/furniture name, %2$s: prying tool name you.add_msg_if_player( _( "You attempt to pry open the %1$s using your %2$s…" ), target_name, best_prying.tname() ); - iuse::crowbar( &you, &best_prying, examp.raw() ); + iuse::crowbar( &you, &best_prying, examp ); } else if( action == act::pick ) { locked_object_pickable( you, examp ); } @@ -1990,7 +1990,7 @@ void iexamine::locked_object_pickable( Character &you, const tripoint_bub_ms &ex const use_function *iuse_fn = it->type->get_use( "PICK_LOCK" ); you.add_msg_if_player( _( "You attempt to pick the lock of %1$s using your %2$s…" ), target_name, it->tname() ); - const ret_val can_use = iuse_fn->can_call( you, *it, examp.raw() ); + const ret_val can_use = iuse_fn->can_call( you, *it, examp ); if( can_use.success() ) { iuse_fn->call( &you, *it, examp ); return; @@ -3438,7 +3438,7 @@ static void add_firestarter( item *it, std::multimap &firestarters, const use_function *usef = it->type->get_use( "firestarter" ); if( usef != nullptr && usef->get_actor_ptr() != nullptr ) { const firestarter_actor *actor = dynamic_cast( usef->get_actor_ptr() ); - if( actor->can_use( you, *it, examp.raw() ).success() ) { + if( actor->can_use( you, *it, examp ).success() ) { firestarters.insert( std::pair( actor->moves_cost_fast, it ) ); } } @@ -3517,9 +3517,9 @@ void iexamine::fireplace( Character &you, const tripoint_bub_ms &examp ) const use_function *usef = it->type->get_use( "firestarter" ); const firestarter_actor *actor = dynamic_cast( usef->get_actor_ptr() ); you.add_msg_if_player( _( "You attempt to start a fire with your %s…" ), it->tname() ); - const ret_val can_use = actor->can_use( you, *it, examp.raw() ); + const ret_val can_use = actor->can_use( you, *it, examp ); if( can_use.success() ) { - const int charges = actor->use( &you, *it, examp.raw() ).value_or( 0 ); + const int charges = actor->use( &you, *it, examp ).value_or( 0 ); you.use_charges( it->typeId(), charges ); return; } else { diff --git a/src/item_action.cpp b/src/item_action.cpp index 35b715077e286..2430206ea09a1 100644 --- a/src/item_action.cpp +++ b/src/item_action.cpp @@ -147,7 +147,7 @@ item_action_map item_action_generator::map_actions_to_items( Character &you, const use_function *func = actual_item->get_use( use ); if( !( func && func->get_actor_ptr() && - func->get_actor_ptr()->can_use( you, *actual_item, you.pos() ).success() ) ) { + func->get_actor_ptr()->can_use( you, *actual_item, you.pos_bub() ).success() ) ) { continue; } @@ -382,7 +382,7 @@ std::string use_function::get_type() const } } -ret_val iuse_actor::can_use( const Character &, const item &, const tripoint & ) const +ret_val iuse_actor::can_use( const Character &, const item &, const tripoint_bub_ms & ) const { return ret_val::make_success(); } diff --git a/src/item_factory.cpp b/src/item_factory.cpp index dab3a3537ddff..6f4c39501c0ee 100644 --- a/src/item_factory.cpp +++ b/src/item_factory.cpp @@ -1664,7 +1664,7 @@ class iuse_function_wrapper : public iuse_actor : iuse_actor( type ), cpp_function( f ) { } ~iuse_function_wrapper() override = default; - std::optional use( Character *p, item &it, const tripoint &pos ) const override { + std::optional use( Character *p, item &it, const tripoint_bub_ms &pos ) const override { return cpp_function( p, &it, pos ); } std::unique_ptr clone() const override { diff --git a/src/itype.cpp b/src/itype.cpp index 96ed079477de5..083cabf280a00 100644 --- a/src/itype.cpp +++ b/src/itype.cpp @@ -184,9 +184,10 @@ const use_function *itype::get_use( const std::string &iuse_name ) const int itype::tick( Character *p, item &it, const tripoint &pos ) const { + const tripoint_bub_ms position{pos}; // TODO: Get rid of this when operation typified int charges_to_use = 0; for( const auto &method : tick_action ) { - charges_to_use += method.second.call( p, it, pos ).value_or( 0 ); + charges_to_use += method.second.call( p, it, position ).value_or( 0 ); } return charges_to_use; @@ -207,6 +208,7 @@ std::optional itype::invoke( Character *p, item &it, const tripoint &pos ) std::optional itype::invoke( Character *p, item &it, const tripoint &pos, const std::string &iuse_name ) const { + const tripoint_bub_ms position{ pos }; // TODO: Get rid of this when operation typified. const use_function *use = get_use( iuse_name ); if( use == nullptr ) { debugmsg( "Tried to invoke %s on a %s, which doesn't have this use_function", @@ -214,7 +216,7 @@ std::optional itype::invoke( Character *p, item &it, const tripoint &pos, return 0; } if( p ) { - const auto ret = use->can_call( *p, it, pos ); + const auto ret = use->can_call( *p, it, position ); if( !ret.success() ) { p->add_msg_if_player( m_info, ret.str() ); @@ -222,7 +224,7 @@ std::optional itype::invoke( Character *p, item &it, const tripoint &pos, } } - return use->call( p, it, pos ); + return use->call( p, it, position ); } std::string gun_type_type::name() const diff --git a/src/iuse.cpp b/src/iuse.cpp index 757bfdd7d4067..bff1e8551c2a5 100644 --- a/src/iuse.cpp +++ b/src/iuse.cpp @@ -414,28 +414,29 @@ static std::string format_object_pair( const std::pair &pair, static std::string format_object_pair_article( const std::pair &pair ); static std::string format_object_pair_no_article( const std::pair &pair ); -static std::string colorized_field_description_at( const tripoint &point ); -static std::string colorized_trap_name_at( const tripoint &point ); -static std::string colorized_ter_name_flags_at( const tripoint &point, +static std::string colorized_field_description_at( const tripoint_bub_ms &point ); +static std::string colorized_trap_name_at( const tripoint_bub_ms &point ); +static std::string colorized_ter_name_flags_at( const tripoint_bub_ms &point, const std::vector &flags = {}, const std::vector &ter_whitelist = {} ); -static std::string colorized_feature_description_at( const tripoint ¢er_point, bool &item_found, +static std::string colorized_feature_description_at( const tripoint_bub_ms ¢er_point, + bool &item_found, const units::volume &min_visible_volume ); static std::string colorized_item_name( const item &item ); static std::string colorized_item_description( const item &item ); -static item get_top_item_at_point( const tripoint &point, +static item get_top_item_at_point( const tripoint_bub_ms &point, const units::volume &min_visible_volume ); static std::string effects_description_for_creature( Creature *creature, std::string &pose, const std::string &pronoun_gender ); -static object_names_collection enumerate_objects_around_point( const tripoint &point, - int radius, const tripoint &bounds_center_point, int bounds_radius, - const tripoint &camera_pos, const units::volume &min_visible_volume, bool create_figure_desc, - std::unordered_set &ignored_points, +static object_names_collection enumerate_objects_around_point( const tripoint_bub_ms &point, + int radius, const tripoint_bub_ms &bounds_center_point, int bounds_radius, + const tripoint_bub_ms &camera_pos, const units::volume &min_visible_volume, bool create_figure_desc, + std::unordered_set &ignored_points, std::unordered_set &vehicles_recorded ); -static item::extended_photo_def photo_def_for_camera_point( const tripoint &aim_point, - const tripoint &camera_pos, +static item::extended_photo_def photo_def_for_camera_point( const tripoint_bub_ms &aim_point, + const tripoint_bub_ms &camera_pos, std::vector &monster_vec, std::vector &character_vec ); static const std::vector camera_ter_whitelist_flags = { @@ -482,7 +483,7 @@ std::optional iuse::can_smoke( const Character &you ) return std::nullopt; } -std::optional iuse::sewage( Character *p, item *, const tripoint & ) +std::optional iuse::sewage( Character *p, item *, const tripoint_bub_ms & ) { if( !p->query_yn( _( "Are you sure you want to drink… this?" ) ) ) { return std::nullopt; @@ -493,13 +494,13 @@ std::optional iuse::sewage( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::honeycomb( Character *p, item *, const tripoint & ) +std::optional iuse::honeycomb( Character *p, item *, const tripoint_bub_ms & ) { get_map().spawn_item( p->pos_bub(), itype_wax, 2 ); return 1; } -std::optional iuse::xanax( Character *p, item *it, const tripoint & ) +std::optional iuse::xanax( Character *p, item *it, const tripoint_bub_ms & ) { p->add_msg_if_player( _( "You take some %s." ), it->tname() ); p->add_effect( effect_took_xanax, 90_minutes ); @@ -536,17 +537,17 @@ static int alcohol( Character &p, const item &it, const int strength ) return 1; } -std::optional iuse::alcohol_weak( Character *p, item *it, const tripoint & ) +std::optional iuse::alcohol_weak( Character *p, item *it, const tripoint_bub_ms & ) { return alcohol( *p, *it, 0 ); } -std::optional iuse::alcohol_medium( Character *p, item *it, const tripoint & ) +std::optional iuse::alcohol_medium( Character *p, item *it, const tripoint_bub_ms & ) { return alcohol( *p, *it, 1 ); } -std::optional iuse::alcohol_strong( Character *p, item *it, const tripoint & ) +std::optional iuse::alcohol_strong( Character *p, item *it, const tripoint_bub_ms & ) { return alcohol( *p, *it, 2 ); } @@ -559,7 +560,7 @@ std::optional iuse::alcohol_strong( Character *p, item *it, const tripoint * @param it the item to be smoked. * @return Charges used in item smoked */ -std::optional iuse::smoking( Character *p, item *it, const tripoint & ) +std::optional iuse::smoking( Character *p, item *it, const tripoint_bub_ms & ) { std::optional litcig = can_smoke( *p ); if( litcig.has_value() ) { @@ -613,7 +614,7 @@ std::optional iuse::smoking( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::ecig( Character *p, item *it, const tripoint & ) +std::optional iuse::ecig( Character *p, item *it, const tripoint_bub_ms & ) { if( it->typeId() == itype_ecig ) { p->add_msg_if_player( m_neutral, _( "You take a puff from your electronic cigarette." ) ); @@ -640,7 +641,7 @@ std::optional iuse::ecig( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::antibiotic( Character *p, item *, const tripoint & ) +std::optional iuse::antibiotic( Character *p, item *, const tripoint_bub_ms & ) { p->add_msg_player_or_npc( m_neutral, _( "You take some antibiotics." ), @@ -662,7 +663,7 @@ std::optional iuse::antibiotic( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::eyedrops( Character *p, item *it, const tripoint & ) +std::optional iuse::eyedrops( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_underwater() ) { return std::nullopt; @@ -687,7 +688,7 @@ std::optional iuse::eyedrops( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::fungicide( Character *p, item *, const tripoint & ) +std::optional iuse::fungicide( Character *p, item *, const tripoint_bub_ms & ) { if( p->cant_do_underwater() ) { return std::nullopt; @@ -744,7 +745,7 @@ std::optional iuse::fungicide( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::antifungal( Character *p, item *, const tripoint & ) +std::optional iuse::antifungal( Character *p, item *, const tripoint_bub_ms & ) { if( p->cant_do_underwater() ) { return std::nullopt; @@ -762,7 +763,7 @@ std::optional iuse::antifungal( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::antiparasitic( Character *p, item *, const tripoint & ) +std::optional iuse::antiparasitic( Character *p, item *, const tripoint_bub_ms & ) { if( p->cant_do_underwater() ) { return std::nullopt; @@ -811,7 +812,7 @@ std::optional iuse::antiparasitic( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::anticonvulsant( Character *p, item *, const tripoint & ) +std::optional iuse::anticonvulsant( Character *p, item *, const tripoint_bub_ms & ) { p->add_msg_if_player( _( "You take some anticonvulsant medication." ) ); /** @EFFECT_STR reduces duration of anticonvulsant medication */ @@ -832,7 +833,7 @@ std::optional iuse::anticonvulsant( Character *p, item *, const tripoint & return 1; } -std::optional iuse::weed_cake( Character *p, item *, const tripoint & ) +std::optional iuse::weed_cake( Character *p, item *, const tripoint_bub_ms & ) { p->add_msg_if_player( _( "You start scarfing down the delicious cake. It tastes a little funny, though…" ) ); @@ -856,7 +857,7 @@ std::optional iuse::weed_cake( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::coke( Character *p, item *, const tripoint & ) +std::optional iuse::coke( Character *p, item *, const tripoint_bub_ms & ) { p->add_msg_if_player( _( "You snort a bump of coke." ) ); /** @EFFECT_STR reduces duration of coke */ @@ -872,7 +873,7 @@ std::optional iuse::coke( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::meth( Character *p, item *, const tripoint & ) +std::optional iuse::meth( Character *p, item *, const tripoint_bub_ms & ) { /** @EFFECT_STR reduces duration of meth */ time_duration duration = 1_minutes * ( 60 - p->str_cur ); @@ -910,7 +911,7 @@ std::optional iuse::meth( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::flu_vaccine( Character *p, item *it, const tripoint & ) +std::optional iuse::flu_vaccine( Character *p, item *it, const tripoint_bub_ms & ) { p->add_msg_if_player( _( "You inject the vaccine." ) ); time_point expiration_date = it->birthday() + 24_weeks; @@ -929,7 +930,7 @@ std::optional iuse::flu_vaccine( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::poison( Character *p, item *it, const tripoint & ) +std::optional iuse::poison( Character *p, item *it, const tripoint_bub_ms & ) { if( p->has_trait( trait_EATDEAD ) ) { return 1; @@ -951,7 +952,7 @@ std::optional iuse::poison( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::meditate( Character *p, item *it, const tripoint & ) +std::optional iuse::meditate( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action meditate that requires character but no character is present", @@ -970,7 +971,7 @@ std::optional iuse::meditate( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::thorazine( Character *p, item *, const tripoint & ) +std::optional iuse::thorazine( Character *p, item *, const tripoint_bub_ms & ) { if( p->has_effect( effect_took_thorazine ) ) { p->remove_effect( effect_took_thorazine ); @@ -995,7 +996,7 @@ std::optional iuse::thorazine( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::prozac( Character *p, item *, const tripoint & ) +std::optional iuse::prozac( Character *p, item *, const tripoint_bub_ms & ) { if( !p->has_effect( effect_took_prozac ) ) { p->add_effect( effect_took_prozac, 12_hours ); @@ -1010,7 +1011,7 @@ std::optional iuse::prozac( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::datura( Character *p, item *it, const tripoint & ) +std::optional iuse::datura( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_npc() ) { return std::nullopt; @@ -1024,14 +1025,14 @@ std::optional iuse::datura( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::flumed( Character *p, item *it, const tripoint & ) +std::optional iuse::flumed( Character *p, item *it, const tripoint_bub_ms & ) { p->add_effect( effect_took_flumed, 10_hours ); p->add_msg_if_player( _( "You take some %s." ), it->tname() ); return 1; } -std::optional iuse::flusleep( Character *p, item *it, const tripoint & ) +std::optional iuse::flusleep( Character *p, item *it, const tripoint_bub_ms & ) { p->add_effect( effect_took_flumed, 12_hours ); p->mod_sleepiness( 30 ); @@ -1040,7 +1041,7 @@ std::optional iuse::flusleep( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::inhaler( Character *p, item *, const tripoint & ) +std::optional iuse::inhaler( Character *p, item *, const tripoint_bub_ms & ) { p->add_msg_player_or_npc( m_neutral, _( "You take a puff from your inhaler." ), _( " takes a puff from their inhaler." ) ); @@ -1055,7 +1056,7 @@ std::optional iuse::inhaler( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::oxygen_bottle( Character *p, item *it, const tripoint & ) +std::optional iuse::oxygen_bottle( Character *p, item *it, const tripoint_bub_ms & ) { p->mod_moves( -to_moves( 10_seconds ) ); p->add_msg_player_or_npc( m_neutral, string_format( _( "You breathe deeply from the %s." ), @@ -1076,7 +1077,7 @@ std::optional iuse::oxygen_bottle( Character *p, item *it, const tripoint & return 1; } -std::optional iuse::blech( Character *p, item *it, const tripoint & ) +std::optional iuse::blech( Character *p, item *it, const tripoint_bub_ms & ) { // TODO: Add more effects? if( it->made_of( phase_id::LIQUID ) ) { @@ -1114,7 +1115,7 @@ std::optional iuse::blech( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::blech_because_unclean( Character *p, item *it, const tripoint & ) +std::optional iuse::blech_because_unclean( Character *p, item *it, const tripoint_bub_ms & ) { if( !p->is_npc() ) { if( test_mode ) { @@ -1135,7 +1136,7 @@ std::optional iuse::blech_because_unclean( Character *p, item *it, const tr return 1; } -std::optional iuse::plantblech( Character *p, item *it, const tripoint &pos ) +std::optional iuse::plantblech( Character *p, item *it, const tripoint_bub_ms &pos ) { if( p->has_trait( trait_THRESH_PLANT ) ) { double multiplier = -1; @@ -1158,7 +1159,7 @@ std::optional iuse::plantblech( Character *p, item *it, const tripoint &pos } } -std::optional iuse::chew( Character *p, item *it, const tripoint & ) +std::optional iuse::chew( Character *p, item *it, const tripoint_bub_ms & ) { // TODO: Add more effects? p->add_msg_if_player( _( "You chew your %s." ), it->tname() ); @@ -1191,7 +1192,7 @@ static void do_purify( Character &p ) } } -std::optional iuse::purify_smart( Character *p, item *it, const tripoint & ) +std::optional iuse::purify_smart( Character *p, item *it, const tripoint_bub_ms & ) { std::vector valid; // Which flags the player has std::vector valid_names; // Which flags the player has @@ -1410,7 +1411,7 @@ static bool marloss_prevented( const Character &p ) return false; } -std::optional iuse::marloss( Character *p, item *it, const tripoint & ) +std::optional iuse::marloss( Character *p, item *it, const tripoint_bub_ms & ) { if( marloss_prevented( *p ) ) { return std::nullopt; @@ -1422,7 +1423,7 @@ std::optional iuse::marloss( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::marloss_seed( Character *p, item *it, const tripoint & ) +std::optional iuse::marloss_seed( Character *p, item *it, const tripoint_bub_ms & ) { if( !query_yn( _( "Are you sure you want to eat the %s? You could plant it in a mound of dirt." ), colorize( it->tname(), it->color_in_inventory() ) ) ) { @@ -1439,7 +1440,7 @@ std::optional iuse::marloss_seed( Character *p, item *it, const tripoint & return 1; } -std::optional iuse::marloss_gel( Character *p, item *it, const tripoint & ) +std::optional iuse::marloss_gel( Character *p, item *it, const tripoint_bub_ms & ) { if( marloss_prevented( *p ) ) { return std::nullopt; @@ -1451,7 +1452,7 @@ std::optional iuse::marloss_gel( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::mycus( Character *p, item *, const tripoint & ) +std::optional iuse::mycus( Character *p, item *, const tripoint_bub_ms & ) { if( p->is_npc() ) { return 1; @@ -1552,16 +1553,16 @@ std::optional iuse::mycus( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::petfood( Character *p, item *it, const tripoint & ) +std::optional iuse::petfood( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->is_comestible() ) { p->add_msg_if_player( _( "You doubt someone would want to eat %1$s." ), it->tname() ); return std::nullopt; } - const std::optional pnt = choose_adjacent( string_format( - _( "Tame which animal with %s?" ), - it->tname() ) ); + const std::optional pnt = choose_adjacent_bub( string_format( + _( "Tame which animal with %s?" ), + it->tname() ) ); if( !pnt ) { return std::nullopt; } @@ -1642,7 +1643,7 @@ std::optional iuse::petfood( Character *p, item *it, const tripoint & ) return std::nullopt; } -std::optional iuse::radio_mod( Character *p, item *, const tripoint & ) +std::optional iuse::radio_mod( Character *p, item *, const tripoint_bub_ms & ) { if( p->is_npc() ) { // Now THAT would be kinda cruel @@ -1703,7 +1704,7 @@ std::optional iuse::radio_mod( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::remove_all_mods( Character *p, item *, const tripoint & ) +std::optional iuse::remove_all_mods( Character *p, item *, const tripoint_bub_ms & ) { if( !p ) { return std::nullopt; @@ -1739,13 +1740,12 @@ std::optional iuse::remove_all_mods( Character *p, item *, const tripoint & return 0; } -static bool good_fishing_spot( const tripoint &pos, Character *p ) +static bool good_fishing_spot( const tripoint_bub_ms &pos, Character *p ) { - std::unordered_set fishable_locations = g->get_fishable_locations( 60, pos ); + std::unordered_set fishable_locations = g->get_fishable_locations( 60, pos.raw() ); std::vector fishables = g->get_fishable_monsters( fishable_locations ); map &here = get_map(); // isolated little body of water with no definite fish population - // TODO: fix point types const oter_id &cur_omt = overmap_buffer.ter( coords::project_to( here.getglobal( pos ) ) ); std::string om_id = cur_omt.id().c_str(); @@ -1761,7 +1761,7 @@ static bool good_fishing_spot( const tripoint &pos, Character *p ) return true; } -std::optional iuse::fishing_rod( Character *p, item *it, const tripoint & ) +std::optional iuse::fishing_rod( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_npc() ) { // Long actions - NPCs don't like those yet. @@ -1773,7 +1773,7 @@ std::optional iuse::fishing_rod( Character *p, item *it, const tripoint & ) map &here = get_map(); std::optional found; for( const tripoint_bub_ms &pnt : here.points_in_radius( p->pos_bub(), 1 ) ) { - if( here.has_flag( ter_furn_flag::TFLAG_FISHABLE, pnt ) && good_fishing_spot( pnt.raw(), p ) ) { + if( here.has_flag( ter_furn_flag::TFLAG_FISHABLE, pnt ) && good_fishing_spot( pnt, p ) ) { found = pnt; break; } @@ -1789,7 +1789,7 @@ std::optional iuse::fishing_rod( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::fish_trap( Character *p, item *it, const tripoint & ) +std::optional iuse::fish_trap( Character *p, item *it, const tripoint_bub_ms & ) { map &here = get_map(); // Handle deploying fish trap. @@ -1810,17 +1810,17 @@ std::optional iuse::fish_trap( Character *p, item *it, const tripoint & ) return std::nullopt; } - const std::optional pnt_ = choose_adjacent( _( "Put fish trap where?" ) ); + const std::optional pnt_ = choose_adjacent_bub( _( "Put fish trap where?" ) ); if( !pnt_ ) { return std::nullopt; } - const tripoint_bub_ms pnt = tripoint_bub_ms( *pnt_ ); + const tripoint_bub_ms pnt = *pnt_; if( !here.has_flag( ter_furn_flag::TFLAG_FISHABLE, pnt ) ) { p->add_msg_if_player( m_info, _( "You can't fish there!" ) ); return std::nullopt; } - if( !good_fishing_spot( pnt.raw(), p ) ) { + if( !good_fishing_spot( pnt, p ) ) { return std::nullopt; } it->active = true; @@ -1834,9 +1834,8 @@ std::optional iuse::fish_trap( Character *p, item *it, const tripoint & ) } -std::optional iuse::fish_trap_tick( Character *p, item *it, const tripoint &pos ) +std::optional iuse::fish_trap_tick( Character *p, item *it, const tripoint_bub_ms &pos ) { - const tripoint_bub_ms position{ pos }; // TODO: Get rid of this when operation typified. map &here = get_map(); // Handle processing fish trap over time. if( it->ammo_remaining() == 0 ) { @@ -1846,7 +1845,7 @@ std::optional iuse::fish_trap_tick( Character *p, item *it, const tripoint if( it->age() > 3_hours ) { it->active = false; - if( !here.has_flag( ter_furn_flag::TFLAG_FISHABLE, position ) ) { + if( !here.has_flag( ter_furn_flag::TFLAG_FISHABLE, pos ) ) { return 0; } @@ -1878,14 +1877,14 @@ std::optional iuse::fish_trap_tick( Character *p, item *it, const tripoint } if( fishes == 0 ) { - it->ammo_consume( it->ammo_remaining(), position, nullptr ); + it->ammo_consume( it->ammo_remaining(), pos, nullptr ); player.practice( skill_survival, rng( 5, 15 ) ); return 0; } //get the fishables around the trap's spot - std::unordered_set fishable_locations = g->get_fishable_locations( 60, position.raw() ); + std::unordered_set fishable_locations = g->get_fishable_locations( 60, pos.raw() ); std::vector fishables = g->get_fishable_monsters( fishable_locations ); for( int i = 0; i < fishes; i++ ) { player.practice( skill_survival, rng( 3, 10 ) ); @@ -1894,9 +1893,9 @@ std::optional iuse::fish_trap_tick( Character *p, item *it, const tripoint // reduce the abstract fish_population marker of that fish chosen_fish->fish_population -= 1; if( chosen_fish->fish_population <= 0 ) { - g->catch_a_monster( chosen_fish, position.raw(), p, 300_hours ); //catch the fish! + g->catch_a_monster( chosen_fish, pos.raw(), p, 300_hours ); //catch the fish! } else { - here.add_item_or_charges( position, item::make_corpse( chosen_fish->type->id, + here.add_item_or_charges( pos, item::make_corpse( chosen_fish->type->id, calendar::turn + rng( 0_turns, 3_hours ) ) ); } @@ -1913,29 +1912,29 @@ std::optional iuse::fish_trap_tick( Character *p, item *it, const tripoint //but it's not as comfortable as if you just put fishes in the same tile with the trap. //Also: corpses and comestibles do not rot in containers like this, but on the ground they will rot. //we don't know when it was caught so use a random turn - here.add_item_or_charges( position, item::make_corpse( fish_mon, it->birthday() + rng( 0_turns, + here.add_item_or_charges( pos, item::make_corpse( fish_mon, it->birthday() + rng( 0_turns, 3_hours ) ) ); break; //this can happen only once } } } - it->ammo_consume( bait_consumed, position, nullptr ); + it->ammo_consume( bait_consumed, pos, nullptr ); } return 0; } -std::optional iuse::extinguisher( Character *p, item *it, const tripoint & ) +std::optional iuse::extinguisher( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->ammo_sufficient( p ) ) { return std::nullopt; } // If anyone other than the player wants to use one of these, // they're going to need to figure out how to aim it. - const std::optional dest_ = choose_adjacent( _( "Spray where?" ) ); + const std::optional dest_ = choose_adjacent_bub( _( "Spray where?" ) ); if( !dest_ ) { return std::nullopt; } - tripoint_bub_ms dest = tripoint_bub_ms( *dest_ ); + tripoint_bub_ms dest = *dest_; p->mod_moves( -to_moves( 2_seconds ) ); @@ -2301,18 +2300,18 @@ class exosuit_interact } }; -std::optional iuse::mace( Character *p, item *it, const tripoint & ) +std::optional iuse::mace( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->ammo_sufficient( p ) ) { return std::nullopt; } // If anyone other than the player wants to use one of these, // they're going to need to figure out how to aim it. - const std::optional dest_ = choose_adjacent( _( "Spray where?" ) ); + const std::optional dest_ = choose_adjacent_bub( _( "Spray where?" ) ); if( !dest_ ) { return std::nullopt; } - tripoint_bub_ms dest = tripoint_bub_ms( *dest_ ); + tripoint_bub_ms dest = *dest_; p->mod_moves( -to_moves( 2_seconds ) ); @@ -2345,7 +2344,7 @@ std::optional iuse::mace( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::manage_exosuit( Character *p, item *it, const tripoint & ) +std::optional iuse::manage_exosuit( Character *p, item *it, const tripoint_bub_ms & ) { if( !p->is_avatar() ) { return std::nullopt; @@ -2358,7 +2357,7 @@ std::optional iuse::manage_exosuit( Character *p, item *it, const tripoint return 0; } -std::optional iuse::unpack_item( Character *p, item *it, const tripoint & ) +std::optional iuse::unpack_item( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_underwater() ) { return std::nullopt; @@ -2372,7 +2371,7 @@ std::optional iuse::unpack_item( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::pack_cbm( Character *p, item *it, const tripoint & ) +std::optional iuse::pack_cbm( Character *p, item *it, const tripoint_bub_ms & ) { item_location bionic = g->inv_map_splice( []( const item & e ) { return e.is_bionic() && e.has_flag( flag_NO_PACKED ); @@ -2403,7 +2402,7 @@ std::optional iuse::pack_cbm( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::pack_item( Character *p, item *it, const tripoint & ) +std::optional iuse::pack_item( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action pack_item that requires character but no character is present", @@ -2433,7 +2432,7 @@ std::optional iuse::pack_item( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::water_purifier( Character *p, item *it, const tripoint & ) +std::optional iuse::water_purifier( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { return std::nullopt; @@ -2523,7 +2522,7 @@ std::optional iuse::purify_water( Character *p, item *purifier, item_locati return std::nullopt; } -std::optional iuse::water_tablets( Character *p, item *it, const tripoint & ) +std::optional iuse::water_tablets( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { return std::nullopt; @@ -2544,7 +2543,7 @@ std::optional iuse::water_tablets( Character *p, item *it, const tripoint & return purify_water( p, it, obj ); } -std::optional iuse::radio_off( Character *p, item *it, const tripoint & ) +std::optional iuse::radio_off( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->ammo_sufficient( p ) ) { p->add_msg_if_player( _( "It's dead." ) ); @@ -2555,7 +2554,7 @@ std::optional iuse::radio_off( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::directional_antenna( Character *p, item *, const tripoint & ) +std::optional iuse::directional_antenna( Character *p, item *, const tripoint_bub_ms & ) { // Find out if we have an active radio auto radios = p->cache_get_items_with( itype_radio_on ); @@ -2610,7 +2609,7 @@ static int radio_static_chance( const radio_tower_reference &tref ) ( max_strength - RADIO_MIN_STRENGTH ) ); } -std::optional iuse::radio_tick( Character *, item *it, const tripoint &pos ) +std::optional iuse::radio_tick( Character *, item *it, const tripoint_bub_ms &pos ) { std::string message = _( "Radio: Kssssssssssssh." ); const radio_tower_reference tref = overmap_buffer.find_radio_station( it->frequency ); @@ -2664,7 +2663,7 @@ std::optional iuse::radio_tick( Character *, item *it, const tripoint &pos return 1; } -std::optional iuse::radio_on( Character *, item *it, const tripoint & ) +std::optional iuse::radio_on( Character *, item *it, const tripoint_bub_ms & ) { const auto tower_desc = []( const int noise ) { @@ -2713,14 +2712,14 @@ std::optional iuse::radio_on( Character *, item *it, const tripoint & ) return 1; } -std::optional iuse::noise_emitter_on( Character *, item *, const tripoint &pos ) +std::optional iuse::noise_emitter_on( Character *, item *, const tripoint_bub_ms &pos ) { sounds::sound( pos, 30, sounds::sound_t::alarm, _( "KXSHHHHRRCRKLKKK!" ), true, "tool", "noise_emitter" ); return 1; } -std::optional iuse::emf_passive_on( Character *, item *, const tripoint &pos ) +std::optional iuse::emf_passive_on( Character *, item *, const tripoint_bub_ms &pos ) { // need to calculate distance to closest electrical thing @@ -2738,7 +2737,7 @@ std::optional iuse::emf_passive_on( Character *, item *, const tripoint &po return 1; } - for( const tripoint &loc : closest_points_first( pos, max ) ) { + for( const tripoint_bub_ms &loc : closest_points_first( pos, max ) ) { const Creature *critter = creatures.creature_at( loc ); // if the creature exists and is either a robot or electric @@ -2774,7 +2773,7 @@ std::optional iuse::emf_passive_on( Character *, item *, const tripoint &po return 1; } -std::optional iuse::ma_manual( Character *p, item *it, const tripoint & ) +std::optional iuse::ma_manual( Character *p, item *it, const tripoint_bub_ms & ) { // [CR] - should NPCs just be allowed to learn this stuff? Just like that? @@ -2791,12 +2790,12 @@ std::optional iuse::ma_manual( Character *p, item *it, const tripoint & ) } // TODO: Why does this exist? -std::optional iuse::crowbar_weak( Character *p, item *it, const tripoint &pos ) +std::optional iuse::crowbar_weak( Character *p, item *it, const tripoint_bub_ms &pos ) { return iuse::crowbar( p, it, pos ); } -std::optional iuse::crowbar( Character *p, item *it, const tripoint &pos ) +std::optional iuse::crowbar( Character *p, item *it, const tripoint_bub_ms &pos ) { if( p->cant_do_mounted() ) { return std::nullopt; @@ -2815,8 +2814,8 @@ std::optional iuse::crowbar( Character *p, item *it, const tripoint &pos ) return false; }; - const std::optional pnt_ = ( pos != p->pos_bub().raw() ) ? tripoint_bub_ms( - pos ) : choose_adjacent_highlight( + const std::optional pnt_ = ( pos != p->pos_bub() ) ? + pos : choose_adjacent_highlight( _( "Pry where?" ), _( "There is nothing to pry nearby." ), f, false ); if( !pnt_ ) { return std::nullopt; @@ -2872,7 +2871,7 @@ std::optional iuse::crowbar( Character *p, item *it, const tripoint &pos ) return std::nullopt; } -std::optional iuse::makemound( Character *p, item *it, const tripoint & ) +std::optional iuse::makemound( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action makemound that requires character but no character is present", @@ -2882,13 +2881,13 @@ std::optional iuse::makemound( Character *p, item *it, const tripoint & ) if( p->cant_do_mounted() ) { return std::nullopt; } - const std::optional pnt_ = choose_adjacent( _( "Till soil where?" ) ); + const std::optional pnt_ = choose_adjacent_bub( _( "Till soil where?" ) ); if( !pnt_ ) { return std::nullopt; } - const tripoint pnt = *pnt_; + const tripoint_bub_ms pnt = *pnt_; - if( pnt == p->pos() ) { + if( pnt == p->pos_bub() ) { p->add_msg_if_player( m_info, _( "You think about jumping on a shovel, but then change your mind." ) ); return std::nullopt; @@ -2907,7 +2906,7 @@ std::optional iuse::makemound( Character *p, item *it, const tripoint & ) } } -std::optional iuse::dig( Character *p, item *it, const tripoint & ) +std::optional iuse::dig( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action dig that requires character but no character is present", @@ -2931,7 +2930,7 @@ std::optional iuse::dig( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::dig_channel( Character *p, item *it, const tripoint & ) +std::optional iuse::dig_channel( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action dig_channel that requires character but no character is present", @@ -2951,7 +2950,7 @@ std::optional iuse::dig_channel( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::fill_pit( Character *p, item *it, const tripoint & ) +std::optional iuse::fill_pit( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action fill_pit that requires character but no character is present", @@ -2971,7 +2970,7 @@ std::optional iuse::fill_pit( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::clear_rubble( Character *p, item *it, const tripoint & ) +std::optional iuse::clear_rubble( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action clear_rubble that requires character but no character is present", @@ -2991,13 +2990,13 @@ std::optional iuse::clear_rubble( Character *p, item *it, const tripoint & return 0; } -std::optional iuse::siphon( Character *p, item *, const tripoint & ) +std::optional iuse::siphon( Character *p, item *, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { return std::nullopt; } map &here = get_map(); - const std::function f = [&here]( const tripoint & pnt ) { + const std::function f = [&here]( const tripoint_bub_ms & pnt ) { const optional_vpart_position vp = here.veh_at( pnt ); return !!vp; }; @@ -3022,8 +3021,8 @@ std::optional iuse::siphon( Character *p, item *, const tripoint & ) } } if( found_more_than_one ) { - std::optional pnt_ = choose_adjacent_highlight( - _( "Siphon from where?" ), _( "There is nothing to siphon from nearby." ), f, false ); + std::optional pnt_ = choose_adjacent_highlight( + _( "Siphon from where?" ), _( "There is nothing to siphon from nearby." ), f, false ); if( !pnt_ ) { return std::nullopt; } @@ -3041,7 +3040,7 @@ std::optional iuse::siphon( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::change_eyes( Character *p, item *, const tripoint & ) +std::optional iuse::change_eyes( Character *p, item *, const tripoint_bub_ms & ) { if( p->is_avatar() ) { p->customize_appearance( customize_appearance_choice::EYES ); @@ -3049,7 +3048,7 @@ std::optional iuse::change_eyes( Character *p, item *, const tripoint & ) return std::nullopt; } -std::optional iuse::change_skin( Character *p, item *, const tripoint & ) +std::optional iuse::change_skin( Character *p, item *, const tripoint_bub_ms & ) { if( p->is_avatar() ) { p->customize_appearance( customize_appearance_choice::SKIN ); @@ -3057,7 +3056,7 @@ std::optional iuse::change_skin( Character *p, item *, const tripoint & ) return std::nullopt; } -static std::optional dig_tool( Character *p, item *it, const tripoint &pos, +static std::optional dig_tool( Character *p, item *it, const tripoint_bub_ms &pos, const activity_id activity, const std::string &prompt, const std::string &fail, const std::string &success, int extra_moves = 0 ) @@ -3075,12 +3074,12 @@ static std::optional dig_tool( Character *p, item *it, const tripoint &pos, } tripoint_bub_ms pnt( pos ); - if( pos == p->pos_bub().raw() ) { - const std::optional pnt_ = choose_adjacent( prompt ); + if( pos == p->pos_bub() ) { + const std::optional pnt_ = choose_adjacent_bub( prompt ); if( !pnt_ ) { return std::nullopt; } - pnt = tripoint_bub_ms( *pnt_ ); + pnt = *pnt_; } map &here = get_map(); @@ -3129,7 +3128,7 @@ static std::optional dig_tool( Character *p, item *it, const tripoint &pos, return 0; // handled when the activity finishes } -std::optional iuse::jackhammer( Character *p, item *it, const tripoint &pos ) +std::optional iuse::jackhammer( Character *p, item *it, const tripoint_bub_ms &pos ) { // use has_enough_charges to check for UPS availability // p is assumed to exist for iuse cases @@ -3143,7 +3142,7 @@ std::optional iuse::jackhammer( Character *p, item *it, const tripoint &pos } -std::optional iuse::pick_lock( Character *p, item *it, const tripoint &pos ) +std::optional iuse::pick_lock( Character *p, item *it, const tripoint_bub_ms &pos ) { if( p->is_npc() ) { return std::nullopt; @@ -3152,10 +3151,10 @@ std::optional iuse::pick_lock( Character *p, item *it, const tripoint &pos std::optional target; // Prompt for a target lock to pick, or use the given tripoint - if( pos == you.pos() ) { + if( pos == you.pos_bub() ) { target = lockpick_activity_actor::select_location( you ); } else { - target = tripoint_bub_ms( pos ); + target = pos; } if( !target.has_value() ) { return std::nullopt; @@ -3190,7 +3189,7 @@ std::optional iuse::pick_lock( Character *p, item *it, const tripoint &pos return 1; } -std::optional iuse::pickaxe( Character *p, item *it, const tripoint &pos ) +std::optional iuse::pickaxe( Character *p, item *it, const tripoint_bub_ms &pos ) { if( p->is_npc() ) { // Long action @@ -3205,7 +3204,7 @@ std::optional iuse::pickaxe( Character *p, item *it, const tripoint &pos ) } -std::optional iuse::geiger( Character *p, item *it, const tripoint & ) +std::optional iuse::geiger( Character *p, item *it, const tripoint_bub_ms & ) { int ch = uilist( _( "Geiger counter:" ), { _( "Scan yourself or other person" ), _( "Scan the ground" ), _( "Turn continuous scan on" ) @@ -3213,17 +3212,17 @@ std::optional iuse::geiger( Character *p, item *it, const tripoint & ) creature_tracker &creatures = get_creature_tracker(); switch( ch ) { case 0: { - const std::function f = [&]( const tripoint & pnt ) { + const std::function f = [&]( const tripoint_bub_ms & pnt ) { return creatures.creature_at( pnt ) != nullptr; }; - const std::optional pnt_ = choose_adjacent_highlight( _( "Scan whom?" ), - _( "There is no one to scan nearby." ), f, false ); + const std::optional pnt_ = choose_adjacent_highlight( _( "Scan whom?" ), + _( "There is no one to scan nearby." ), f, false ); if( !pnt_ ) { return std::nullopt; } - const tripoint &pnt = *pnt_; - if( pnt == p->pos() ) { + const tripoint_bub_ms &pnt = *pnt_; + if( pnt == p->pos_bub() ) { p->add_msg_if_player( m_info, _( "Your radiation level: %d mSv (%d mSv from items)" ), p->get_rad(), static_cast( p->get_leak_level() ) ); break; @@ -3252,7 +3251,7 @@ std::optional iuse::geiger( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::geiger_active( Character *, item *, const tripoint &pos ) +std::optional iuse::geiger_active( Character *, item *, const tripoint_bub_ms &pos ) { const int rads = get_map().get_radiation( pos ); if( rads == 0 ) { @@ -3264,7 +3263,7 @@ std::optional iuse::geiger_active( Character *, item *, const tripoint &pos rads > 25 ? _( "geiger_medium" ) : _( "geiger_low" ); sounds::sound( pos, 6, sounds::sound_t::alarm, description, true, "tool", sound_var ); - if( !get_avatar().can_hear( pos, 6 ) ) { + if( !get_avatar().can_hear( pos.raw(), 6 ) ) { // can not hear it, but may have alarmed other creatures return 1; } @@ -3286,7 +3285,7 @@ std::optional iuse::geiger_active( Character *, item *, const tripoint &pos return 1; } -std::optional iuse::teleport( Character *p, item *it, const tripoint & ) +std::optional iuse::teleport( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_npc() ) { // That would be evil @@ -3303,7 +3302,7 @@ std::optional iuse::teleport( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::can_goo( Character *p, item *it, const tripoint & ) +std::optional iuse::can_goo( Character *p, item *it, const tripoint_bub_ms & ) { it->convert( itype_canister_empty ); int tries = 0; @@ -3353,9 +3352,9 @@ std::optional iuse::can_goo( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::granade_act( Character *, item *it, const tripoint &pos ) +std::optional iuse::granade_act( Character *, item *it, const tripoint_bub_ms &pos ) { - if( pos.x == -999 || pos.y == -999 ) { + if( pos.x() == -999 || pos.y() == -999 ) { return std::nullopt; } map &here = get_map(); @@ -3373,7 +3372,7 @@ std::optional iuse::granade_act( Character *, item *it, const tripoint &pos sounds::sound( pos, 100, sounds::sound_t::electronic_speech, _( "BUGFIXES!" ), true, "speech", it->typeId().str() ); explosion_handler::draw_explosion( pos, explosion_radius, c_light_cyan ); - for( const tripoint &dest : here.points_in_radius( pos, explosion_radius ) ) { + for( const tripoint_bub_ms &dest : here.points_in_radius( pos, explosion_radius ) ) { monster *const mon = creatures.creature_at( dest, true ); if( mon && ( mon->type->in_species( species_INSECT ) || mon->is_hallucination() ) ) { mon->die_in_explosion( nullptr ); @@ -3385,7 +3384,7 @@ std::optional iuse::granade_act( Character *, item *it, const tripoint &pos sounds::sound( pos, 100, sounds::sound_t::electronic_speech, _( "BUFFS!" ), true, "speech", it->typeId().str() ); explosion_handler::draw_explosion( pos, explosion_radius, c_green ); - for( const tripoint &dest : here.points_in_radius( pos, explosion_radius ) ) { + for( const tripoint_bub_ms &dest : here.points_in_radius( pos, explosion_radius ) ) { if( monster *const mon_ptr = creatures.creature_at( dest ) ) { monster &critter = *mon_ptr; critter.set_speed_base( @@ -3400,7 +3399,7 @@ std::optional iuse::granade_act( Character *, item *it, const tripoint &pos buff_stat( person->int_max, rng( 0, person->int_max / 2 ) ); /** @EFFECT_PER_MAX increases possible granade per buff for NPCs */ buff_stat( person->per_max, rng( 0, person->per_max / 2 ) ); - } else if( player_character.pos() == dest ) { + } else if( player_character.pos_bub() == dest ) { /** @EFFECT_STR_MAX increases possible granade str buff */ buff_stat( player_character.str_max, rng( 0, player_character.str_max / 2 ) ); /** @EFFECT_DEX_MAX increases possible granade dex buff */ @@ -3427,7 +3426,7 @@ std::optional iuse::granade_act( Character *, item *it, const tripoint &pos sounds::sound( pos, 100, sounds::sound_t::electronic_speech, _( "NERFS!" ), true, "speech", it->typeId().str() ); explosion_handler::draw_explosion( pos, explosion_radius, c_red ); - for( const tripoint &dest : here.points_in_radius( pos, explosion_radius ) ) { + for( const tripoint_bub_ms &dest : here.points_in_radius( pos, explosion_radius ) ) { if( monster *const mon_ptr = creatures.creature_at( dest ) ) { monster &critter = *mon_ptr; critter.set_speed_base( @@ -3442,7 +3441,7 @@ std::optional iuse::granade_act( Character *, item *it, const tripoint &pos person->int_max -= rng( 0, person->int_max / 2 ); /** @EFFECT_PER_MAX increases possible granade per debuff for NPCs (NEGATIVE) */ person->per_max -= rng( 0, person->per_max / 2 ); - } else if( player_character.pos() == dest ) { + } else if( player_character.pos_bub() == dest ) { /** @EFFECT_STR_MAX increases possible granade str debuff (NEGATIVE) */ player_character.str_max -= rng( 0, player_character.str_max / 2 ); /** @EFFECT_DEX_MAX increases possible granade dex debuff (NEGATIVE) */ @@ -3467,7 +3466,7 @@ std::optional iuse::granade_act( Character *, item *it, const tripoint &pos sounds::sound( pos, 100, sounds::sound_t::electronic_speech, _( "REVERTS!" ), true, "speech", it->typeId().str() ); explosion_handler::draw_explosion( pos, explosion_radius, c_pink ); - for( const tripoint &dest : here.points_in_radius( pos, explosion_radius ) ) { + for( const tripoint_bub_ms &dest : here.points_in_radius( pos, explosion_radius ) ) { if( monster *const mon_ptr = creatures.creature_at( dest ) ) { monster &critter = *mon_ptr; critter.set_speed_base( critter.type->speed ); @@ -3475,7 +3474,7 @@ std::optional iuse::granade_act( Character *, item *it, const tripoint &pos critter.clear_effects(); } else if( npc *const person = creatures.creature_at( dest ) ) { person->environmental_revert_effect(); - } else if( player_character.pos() == dest ) { + } else if( player_character.pos_bub() == dest ) { player_character.environmental_revert_effect(); do_purify( player_character ); } @@ -3485,7 +3484,7 @@ std::optional iuse::granade_act( Character *, item *it, const tripoint &pos return 1; } -std::optional iuse::c4( Character *p, item *it, const tripoint & ) +std::optional iuse::c4( Character *p, item *it, const tripoint_bub_ms & ) { int time = 0; bool got_value = false; @@ -3509,12 +3508,12 @@ std::optional iuse::c4( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::acidbomb_act( Character *p, item *it, const tripoint &pos ) +std::optional iuse::acidbomb_act( Character *p, item *it, const tripoint_bub_ms &pos ) { if( !p ) { it->charges = -1; map &here = get_map(); - for( const tripoint_bub_ms &tmp : here.points_in_radius( tripoint_bub_ms( pos ), 1 ) ) { + for( const tripoint_bub_ms &tmp : here.points_in_radius( pos, 1 ) ) { here.add_field( tmp, fd_acid, 3 ); } return 1; @@ -3522,23 +3521,23 @@ std::optional iuse::acidbomb_act( Character *p, item *it, const tripoint &p return std::nullopt; } -std::optional iuse::grenade_inc_act( Character *p, item *, const tripoint &pos ) +std::optional iuse::grenade_inc_act( Character *p, item *, const tripoint_bub_ms &pos ) { - if( pos.x == -999 || pos.y == -999 ) { + if( pos.x() == -999 || pos.y() == -999 ) { return std::nullopt; } map &here = get_map(); int num_flames = rng( 3, 5 ); for( int current_flame = 0; current_flame < num_flames; current_flame++ ) { - tripoint_bub_ms dest( tripoint_bub_ms( pos ) + point( rng( -5, 5 ), rng( -5, 5 ) ) ); - std::vector flames = line_to( tripoint_bub_ms( pos ), dest, 0, 0 ); + tripoint_bub_ms dest( pos + point( rng( -5, 5 ), rng( -5, 5 ) ) ); + std::vector flames = line_to( pos, dest, 0, 0 ); for( tripoint_bub_ms &flame : flames ) { here.add_field( flame, fd_fire, rng( 0, 2 ) ); } } - explosion_handler::explosion( p, pos, 8, 0.8, true ); - for( const tripoint_bub_ms &dest : here.points_in_radius( tripoint_bub_ms( pos ), 2 ) ) { + explosion_handler::explosion( p, pos.raw(), 8, 0.8, true ); + for( const tripoint_bub_ms &dest : here.points_in_radius( pos, 2 ) ) { here.add_field( dest, fd_incendiary, 3 ); } @@ -3551,13 +3550,13 @@ std::optional iuse::grenade_inc_act( Character *p, item *, const tripoint & return 0; } -std::optional iuse::molotov_lit( Character *p, item *it, const tripoint &pos ) +std::optional iuse::molotov_lit( Character *p, item *it, const tripoint_bub_ms &pos ) { if( !p ) { // It was thrown or dropped, so burst into flames map &here = get_map(); - for( const tripoint_bub_ms &pt : here.points_in_radius( tripoint_bub_ms( pos ), 1, 0 ) ) { + for( const tripoint_bub_ms &pt : here.points_in_radius( pos, 1, 0 ) ) { const int intensity = 1 + one_in( 3 ) + one_in( 5 ); here.add_field( pt, fd_fire, intensity ); } @@ -3578,7 +3577,7 @@ std::optional iuse::molotov_lit( Character *p, item *it, const tripoint &po return 0; } -std::optional iuse::firecracker_pack( Character *p, item *it, const tripoint & ) +std::optional iuse::firecracker_pack( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_underwater() ) { return std::nullopt; @@ -3595,7 +3594,7 @@ std::optional iuse::firecracker_pack( Character *p, item *it, const tripoin return 0; // don't use any charges at all. it has became a new item } -std::optional iuse::firecracker_pack_act( Character *, item *it, const tripoint &pos ) +std::optional iuse::firecracker_pack_act( Character *, item *it, const tripoint_bub_ms &pos ) { // Two seconds of lit fuse burning // Followed by random number of explosions (4-6) per turn until 25 epxlosions have happened @@ -3615,7 +3614,7 @@ std::optional iuse::firecracker_pack_act( Character *, item *it, const trip return 0; } -std::optional iuse::firecracker( Character *p, item *it, const tripoint & ) +std::optional iuse::firecracker( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_underwater() ) { return std::nullopt; @@ -3631,7 +3630,7 @@ std::optional iuse::firecracker( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::mininuke( Character *p, item *it, const tripoint & ) +std::optional iuse::mininuke( Character *p, item *it, const tripoint_bub_ms & ) { int time; bool got_value = query_int( time, _( "Set the timer to ___ turns (0 to cancel)?" ) ); @@ -3648,7 +3647,7 @@ std::optional iuse::mininuke( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::portal( Character *p, item *it, const tripoint & ) +std::optional iuse::portal( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->ammo_sufficient( p ) ) { return std::nullopt; @@ -3661,22 +3660,22 @@ std::optional iuse::portal( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::tazer( Character *p, item *it, const tripoint &pos ) +std::optional iuse::tazer( Character *p, item *it, const tripoint_bub_ms &pos ) { if( !it->ammo_sufficient( p ) ) { return std::nullopt; } - tripoint pnt = pos; - if( pos == p->pos() ) { - const std::optional pnt_ = choose_adjacent( _( "Shock where?" ) ); + tripoint_bub_ms pnt = pos; + if( pos == p->pos_bub() ) { + const std::optional pnt_ = choose_adjacent_bub( _( "Shock where?" ) ); if( !pnt_ ) { return std::nullopt; } pnt = *pnt_; } - if( pnt == p->pos() ) { + if( pnt == p->pos_bub() ) { p->add_msg_if_player( m_info, _( "Umm. No." ) ); return std::nullopt; } @@ -3734,7 +3733,7 @@ std::optional iuse::tazer( Character *p, item *it, const tripoint &pos ) return 1; } -std::optional iuse::tazer2( Character *p, item *it, const tripoint &pos ) +std::optional iuse::tazer2( Character *p, item *it, const tripoint_bub_ms &pos ) { if( it->ammo_remaining( p, true ) >= 2 ) { // Instead of having a ctrl+c+v of the function above, spawn a fake tazer and use it @@ -3749,7 +3748,7 @@ std::optional iuse::tazer2( Character *p, item *it, const tripoint &pos ) return std::nullopt; } -std::optional iuse::shocktonfa_off( Character *p, item *it, const tripoint &pos ) +std::optional iuse::shocktonfa_off( Character *p, item *it, const tripoint_bub_ms &pos ) { if( !p ) { debugmsg( "%s called action shocktonfa_off that requires character but no character is present", @@ -3777,7 +3776,7 @@ std::optional iuse::shocktonfa_off( Character *p, item *it, const tripoint return 0; } -std::optional iuse::shocktonfa_on( Character *p, item *it, const tripoint &pos ) +std::optional iuse::shocktonfa_on( Character *p, item *it, const tripoint_bub_ms &pos ) { if( !p ) { // Effects while simply on debugmsg( "%s called action shocktonfa_on that requires character but no character is present", @@ -3805,7 +3804,7 @@ std::optional iuse::shocktonfa_on( Character *p, item *it, const tripoint & return 0; } -std::optional iuse::mp3( Character *p, item *it, const tripoint & ) +std::optional iuse::mp3( Character *p, item *it, const tripoint_bub_ms & ) { // TODO: avoid item id hardcoding to make this function usable for pure json-defined devices. if( !it->ammo_sufficient( p ) ) { @@ -3860,13 +3859,13 @@ static std::string get_music_description() return _( "a sweet guitar solo!" ); } -void iuse::play_music( Character *p, const tripoint &source, const int volume, +void iuse::play_music( Character *p, const tripoint_bub_ms &source, const int volume, const int max_morale, bool play_sounds ) { std::string sound = "music"; auto lambda_should_do_effects = [&source, &volume]( Character * p ) { - return p && p->can_hear( source, volume ) && !p->in_sleep_state(); + return p && p->can_hear( source.raw(), volume ) && !p->in_sleep_state(); }; auto lambda_add_music_effects = [&max_morale, &volume]( Character & guy ) { @@ -3898,7 +3897,7 @@ void iuse::play_music( Character *p, const tripoint &source, const int volume, if( !music.empty() ) { sound = music; // descriptions aren't printed for sounds at our position - if( lambda_should_do_effects( p ) && p->pos() == source ) { + if( lambda_should_do_effects( p ) && p->pos_bub() == source ) { p->add_msg_if_player( _( "You listen to %s" ), music ); } } @@ -3909,7 +3908,7 @@ void iuse::play_music( Character *p, const tripoint &source, const int volume, } } -std::optional iuse::mp3_on( Character *p, item *, const tripoint &pos ) +std::optional iuse::mp3_on( Character *p, item *, const tripoint_bub_ms &pos ) { // mp3 player in inventory, we can listen play_music( p, pos, 0, 20 ); @@ -3917,7 +3916,7 @@ std::optional iuse::mp3_on( Character *p, item *, const tripoint &pos ) return 1; } -std::optional iuse::mp3_deactivate( Character *p, item *it, const tripoint & ) +std::optional iuse::mp3_deactivate( Character *p, item *it, const tripoint_bub_ms & ) { if( it->typeId() == itype_mp3_on ) { @@ -3940,7 +3939,7 @@ std::optional iuse::mp3_deactivate( Character *p, item *it, const tripoint } -std::optional iuse::rpgdie( Character *you, item *die, const tripoint & ) +std::optional iuse::rpgdie( Character *you, item *die, const tripoint_bub_ms & ) { if( you->cant_do_mounted() ) { return std::nullopt; @@ -3962,7 +3961,7 @@ std::optional iuse::rpgdie( Character *you, item *die, const tripoint & ) return roll; } -std::optional iuse::dive_tank( Character *p, item *it, const tripoint & ) +std::optional iuse::dive_tank( Character *p, item *it, const tripoint_bub_ms & ) { if( p && p->is_worn( *it ) ) { if( p->is_underwater() && p->oxygen < 10 ) { @@ -3984,7 +3983,7 @@ std::optional iuse::dive_tank( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::dive_tank_activate( Character *p, item *it, const tripoint & ) +std::optional iuse::dive_tank_activate( Character *p, item *it, const tripoint_bub_ms & ) { if( it->ammo_remaining() == 0 ) { p->add_msg_if_player( _( "Your %s is empty." ), it->tname() ); @@ -4004,7 +4003,7 @@ std::optional iuse::dive_tank_activate( Character *p, item *it, const tripo return 1; } -std::optional iuse::solarpack( Character *p, item *it, const tripoint & ) +std::optional iuse::solarpack( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action solarpack that requires character but no character is present", @@ -4038,7 +4037,7 @@ std::optional iuse::solarpack( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::solarpack_off( Character *p, item *it, const tripoint & ) +std::optional iuse::solarpack_off( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action solarpack_off that requires character but no character is present", @@ -4060,7 +4059,7 @@ std::optional iuse::solarpack_off( Character *p, item *it, const tripoint & return 0; } -std::optional iuse::gasmask_activate( Character *p, item *it, const tripoint & ) +std::optional iuse::gasmask_activate( Character *p, item *it, const tripoint_bub_ms & ) { if( it->ammo_remaining() == 0 ) { p->add_msg_if_player( _( "Your %s doesn't have a filter." ), it->tname() ); @@ -4073,12 +4072,11 @@ std::optional iuse::gasmask_activate( Character *p, item *it, const tripoin return 0; } -std::optional iuse::gasmask( Character *p, item *it, const tripoint &pos ) +std::optional iuse::gasmask( Character *p, item *it, const tripoint_bub_ms &pos ) { - const tripoint_bub_ms position{pos}; // TODO: Get rid of this when operation typified. if( p && p->is_worn( *it ) ) { // calculate amount of absorbed gas per filter charge - const field &gasfield = get_map().field_at( position ); + const field &gasfield = get_map().field_at( pos ); for( const auto &dfield : gasfield ) { const field_entry &entry = dfield.second; int gas_abs_factor = to_turns( entry.get_field_type()->gas_absorption_factor ); @@ -4099,7 +4097,7 @@ std::optional iuse::gasmask( Character *p, item *it, const tripoint &pos ) } } if( it->get_var( "gas_absorbed", 0 ) >= 60 ) { - it->ammo_consume( 1, position, p ); + it->ammo_consume( 1, pos, p ); it->set_var( "gas_absorbed", 0 ); if( it->ammo_remaining() < 10 ) { p->add_msg_player_or_npc( @@ -4125,7 +4123,7 @@ std::optional iuse::gasmask( Character *p, item *it, const tripoint &pos ) return 0; } -std::optional iuse::portable_game( Character *p, item *it, const tripoint & ) +std::optional iuse::portable_game( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_npc() ) { // Long action @@ -4266,7 +4264,7 @@ std::optional iuse::portable_game( Character *p, item *it, const tripoint & return 0; } -std::optional iuse::fitness_check( Character *p, item *it, const tripoint & ) +std::optional iuse::fitness_check( Character *p, item *it, const tripoint_bub_ms & ) { if( p->has_trait( trait_ILLITERATE ) ) { p->add_msg_if_player( m_info, _( "You don't know what you're looking at." ) ); @@ -4317,7 +4315,7 @@ std::optional iuse::fitness_check( Character *p, item *it, const tripoint & return 1; } -std::optional iuse::hand_crank( Character *p, item *it, const tripoint & ) +std::optional iuse::hand_crank( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_npc() ) { // Long action @@ -4351,7 +4349,7 @@ std::optional iuse::hand_crank( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::vibe( Character *p, item *it, const tripoint & ) +std::optional iuse::vibe( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_npc() ) { // Long action @@ -4391,9 +4389,9 @@ std::optional iuse::vibe( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::vortex( Character *p, item *it, const tripoint & ) +std::optional iuse::vortex( Character *p, item *it, const tripoint_bub_ms & ) { - std::vector spawn; + std::vector spawn; spawn.reserve( 28 ); for( int i = -3; i <= 3; i++ ) { spawn.emplace_back( -3, i ); @@ -4403,7 +4401,7 @@ std::optional iuse::vortex( Character *p, item *it, const tripoint & ) } while( !spawn.empty() ) { - const tripoint offset( random_entry_removed( spawn ), 0 ); + const tripoint_bub_ms offset( random_entry_removed( spawn ), 0 ); monster *const mon = g->place_critter_at( mon_vortex, offset + p->pos() ); if( !mon ) { continue; @@ -4420,7 +4418,7 @@ std::optional iuse::vortex( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::dog_whistle( Character *p, item *, const tripoint & ) +std::optional iuse::dog_whistle( Character *p, item *, const tripoint_bub_ms & ) { if( !p->is_avatar() ) { return std::nullopt; @@ -4480,7 +4478,7 @@ std::optional iuse::dog_whistle( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::call_of_tindalos( Character *p, item *, const tripoint & ) +std::optional iuse::call_of_tindalos( Character *p, item *, const tripoint_bub_ms & ) { map &here = get_map(); for( const tripoint_bub_ms &dest : here.points_in_radius( p->pos_bub(), 12 ) ) { @@ -4492,7 +4490,7 @@ std::optional iuse::call_of_tindalos( Character *p, item *, const tripoint return 1; } -std::optional iuse::blood_draw( Character *p, item *it, const tripoint & ) +std::optional iuse::blood_draw( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_npc() ) { return std::nullopt; // No NPCs for now! @@ -4595,7 +4593,7 @@ void iuse::cut_log_into_planks( Character &p ) p.activity.placement = get_map().getglobal( p.pos_bub() ); } -std::optional iuse::lumber( Character *p, item *it, const tripoint & ) +std::optional iuse::lumber( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action lumber that requires character but no character is present", @@ -4648,7 +4646,7 @@ static int chop_moves( Character *p, item *it ) return moves; } -std::optional iuse::chop_tree( Character *p, item *it, const tripoint & ) +std::optional iuse::chop_tree( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action chop_tree that requires character but no character is present", @@ -4659,21 +4657,21 @@ std::optional iuse::chop_tree( Character *p, item *it, const tripoint & ) return std::nullopt; } map &here = get_map(); - const std::function f = [&here, p]( const tripoint & pnt ) { - if( pnt == p->pos() ) { + const std::function f = [&here, p]( const tripoint_bub_ms & pnt ) { + if( pnt == p->pos_bub() ) { return false; } return here.has_flag( ter_furn_flag::TFLAG_TREE, pnt ); }; - const std::optional pnt_ = choose_adjacent_highlight( - _( "Chop down which tree?" ), _( "There is no tree to chop down nearby." ), f, false ); + const std::optional pnt_ = choose_adjacent_highlight( + _( "Chop down which tree?" ), _( "There is no tree to chop down nearby." ), f, false ); if( !pnt_ ) { return std::nullopt; } - const tripoint &pnt = *pnt_; + const tripoint_bub_ms &pnt = *pnt_; if( !f( pnt ) ) { - if( pnt == p->pos() ) { + if( pnt == p->pos_bub() ) { p->add_msg_if_player( m_info, _( "You're not stern enough to shave yourself with THIS." ) ); } else { p->add_msg_if_player( m_info, _( "You can't chop down that." ) ); @@ -4694,7 +4692,7 @@ std::optional iuse::chop_tree( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::chop_logs( Character *p, item *it, const tripoint & ) +std::optional iuse::chop_logs( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action chop_logs that requires character but no character is present", @@ -4710,18 +4708,19 @@ std::optional iuse::chop_logs( Character *p, item *it, const tripoint & ) ter_t_stump }; map &here = get_map(); - const std::function f = [&allowed_ter_id, &here]( const tripoint & pnt ) { + const std::function f = [&allowed_ter_id, + &here]( const tripoint_bub_ms & pnt ) { const ter_id &type = here.ter( pnt ); const bool is_allowed_terrain = allowed_ter_id.find( type.id() ) != allowed_ter_id.end(); return is_allowed_terrain; }; - const std::optional pnt_ = choose_adjacent_highlight( - _( "Chop which tree trunk?" ), _( "There is no tree trunk to chop nearby." ), f, false ); + const std::optional pnt_ = choose_adjacent_highlight( + _( "Chop which tree trunk?" ), _( "There is no tree trunk to chop nearby." ), f, false ); if( !pnt_ ) { return std::nullopt; } - const tripoint &pnt = *pnt_; + const tripoint_bub_ms &pnt = *pnt_; if( !f( pnt ) ) { p->add_msg_if_player( m_info, _( "You can't chop that." ) ); return std::nullopt; @@ -4738,7 +4737,7 @@ std::optional iuse::chop_logs( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::oxytorch( Character *p, item *it, const tripoint & ) +std::optional iuse::oxytorch( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_npc() ) { // Long action @@ -4785,7 +4784,7 @@ std::optional iuse::oxytorch( Character *p, item *it, const tripoint & ) return std::nullopt; } -std::optional iuse::hacksaw( Character *p, item *it, const tripoint &it_pnt ) +std::optional iuse::hacksaw( Character *p, item *it, const tripoint_bub_ms &it_pnt ) { if( !p ) { debugmsg( "%s called action hacksaw that requires character but no character is present", @@ -4824,16 +4823,16 @@ std::optional iuse::hacksaw( Character *p, item *it, const tripoint &it_pnt } return std::nullopt; } - if( p->pos() == it_pnt ) { + if( p->pos_bub() == it_pnt ) { p->assign_activity( hacksaw_activity_actor( pnt, item_location{ *p, it } ) ); } else { - p->assign_activity( hacksaw_activity_actor( pnt, it->typeId(), tripoint_bub_ms( it_pnt ) ) ); + p->assign_activity( hacksaw_activity_actor( pnt, it->typeId(), it_pnt ) ); } return std::nullopt; } -std::optional iuse::boltcutters( Character *p, item *it, const tripoint & ) +std::optional iuse::boltcutters( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { return std::nullopt; @@ -4872,26 +4871,23 @@ std::optional iuse::boltcutters( Character *p, item *it, const tripoint & ) return std::nullopt; } -std::optional iuse::mop( Character *p, item *, const tripoint & ) +std::optional iuse::mop( Character *p, item *, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { return std::nullopt; } map &here = get_map(); - const std::function f = [&here]( const tripoint & pnt ) { - // TODO: fix point types - return here.terrain_moppable( tripoint_bub_ms( pnt ) ); + const std::function f = [&here]( const tripoint_bub_ms & pnt ) { + return here.terrain_moppable( pnt ); }; - const std::optional pnt_ = choose_adjacent_highlight( - _( "Mop where?" ), _( "There is nothing to mop nearby." ), f, false ); + const std::optional pnt_ = choose_adjacent_highlight( + _( "Mop where?" ), _( "There is nothing to mop nearby." ), f, false ); if( !pnt_ ) { return std::nullopt; } - // TODO: fix point types const tripoint_bub_ms pnt( *pnt_ ); - // TODO: fix point types - if( !f( pnt.raw() ) ) { + if( !f( pnt ) ) { if( pnt == p->pos_bub() ) { p->add_msg_if_player( m_info, _( "You mop yourself up." ) ); p->add_msg_if_player( m_info, _( "The universe implodes and reforms around you." ) ); @@ -4915,9 +4911,9 @@ std::optional iuse::mop( Character *p, item *, const tripoint & ) return 1; } -std::optional iuse::spray_can( Character *p, item *it, const tripoint & ) +std::optional iuse::spray_can( Character *p, item *it, const tripoint_bub_ms & ) { - const std::optional dest_ = choose_adjacent( _( "Spray where?" ) ); + const std::optional dest_ = choose_adjacent_bub( _( "Spray where?" ) ); if( !dest_ ) { return std::nullopt; } @@ -4925,7 +4921,7 @@ std::optional iuse::spray_can( Character *p, item *it, const tripoint & ) } std::optional iuse::handle_ground_graffiti( Character &p, item *it, const std::string &prefix, - const tripoint &where ) + const tripoint_bub_ms &where ) { map &here = get_map(); string_input_popup popup; @@ -5000,7 +4996,7 @@ static bool heat_item( Character &p ) return true; } -std::optional iuse::heatpack( Character *p, item *it, const tripoint & ) +std::optional iuse::heatpack( Character *p, item *it, const tripoint_bub_ms & ) { if( heat_item( *p ) ) { it->convert( itype_heatpack_used, p ); @@ -5008,7 +5004,7 @@ std::optional iuse::heatpack( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::heat_food( Character *p, item *it, const tripoint & ) +std::optional iuse::heat_food( Character *p, item *it, const tripoint_bub_ms & ) { if( get_map().has_nearby_fire( p->pos_bub() ) ) { heat_item( *p ); @@ -5027,7 +5023,7 @@ std::optional iuse::heat_food( Character *p, item *it, const tripoint & ) return std::nullopt; } -std::optional iuse::hotplate( Character *p, item *it, const tripoint & ) +std::optional iuse::hotplate( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { return std::nullopt; @@ -5043,7 +5039,7 @@ std::optional iuse::hotplate( Character *p, item *it, const tripoint & ) return std::nullopt; } -std::optional iuse::hotplate_atomic( Character *p, item *it, const tripoint & ) +std::optional iuse::hotplate_atomic( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { return std::nullopt; @@ -5055,7 +5051,7 @@ std::optional iuse::hotplate_atomic( Character *p, item *it, const tripoint return std::nullopt; } -std::optional iuse::towel( Character *p, item *it, const tripoint & ) +std::optional iuse::towel( Character *p, item *it, const tripoint_bub_ms & ) { return towel_common( p, it, false ); } @@ -5130,14 +5126,14 @@ int iuse::towel_common( Character *p, item *it, bool ) return it ? 1 : 0; } -std::optional iuse::unfold_generic( Character *p, item *it, const tripoint & ) +std::optional iuse::unfold_generic( Character *p, item *it, const tripoint_bub_ms & ) { p->assign_activity( vehicle_unfolding_activity_actor( *it ) ); p->i_rem( it ); return 0; } -std::optional iuse::adrenaline_injector( Character *p, item *it, const tripoint & ) +std::optional iuse::adrenaline_injector( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_npc() && p->get_effect_dur( effect_adrenaline ) >= 30_minutes ) { return std::nullopt; @@ -5160,7 +5156,7 @@ std::optional iuse::adrenaline_injector( Character *p, item *it, const trip return 1; } -std::optional iuse::jet_injector( Character *p, item *it, const tripoint & ) +std::optional iuse::jet_injector( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->ammo_sufficient( p ) ) { p->add_msg_if_player( m_info, _( "The jet injector is empty." ) ); @@ -5182,7 +5178,7 @@ std::optional iuse::jet_injector( Character *p, item *it, const tripoint & return 1; } -std::optional iuse::stimpack( Character *p, item *it, const tripoint & ) +std::optional iuse::stimpack( Character *p, item *it, const tripoint_bub_ms & ) { if( p->get_item_position( it ) >= -1 ) { p->add_msg_if_player( m_info, @@ -5205,7 +5201,7 @@ std::optional iuse::stimpack( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::radglove( Character *p, item *it, const tripoint & ) +std::optional iuse::radglove( Character *p, item *it, const tripoint_bub_ms & ) { if( p->get_item_position( it ) >= -1 ) { p->add_msg_if_player( m_info, @@ -5233,7 +5229,7 @@ std::optional iuse::radglove( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::talking_doll( Character *p, item *it, const tripoint & ) +std::optional iuse::talking_doll( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->ammo_sufficient( p ) ) { p->add_msg_if_player( m_info, _( "The %s's batteries are dead." ), it->tname() ); @@ -5248,7 +5244,7 @@ std::optional iuse::talking_doll( Character *p, item *it, const tripoint & return 1; } -std::optional iuse::gun_repair( Character *p, item *it, const tripoint & ) +std::optional iuse::gun_repair( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->ammo_sufficient( p ) ) { return std::nullopt; @@ -5303,7 +5299,7 @@ std::optional gun_repair( Character *p, item *, item_location &loc ) return 1; } -std::optional iuse::gunmod_attach( Character *p, item *it, const tripoint & ) +std::optional iuse::gunmod_attach( Character *p, item *it, const tripoint_bub_ms & ) { if( !it || !it->is_gunmod() ) { debugmsg( "tried to attach non-gunmod" ); @@ -5340,7 +5336,7 @@ std::optional iuse::gunmod_attach( Character *p, item *it, const tripoint & } while( true ); } -std::optional iuse::toolmod_attach( Character *p, item *it, const tripoint & ) +std::optional iuse::toolmod_attach( Character *p, item *it, const tripoint_bub_ms & ) { if( !it || !it->is_toolmod() ) { debugmsg( "tried to attach non-toolmod" ); @@ -5395,7 +5391,7 @@ std::optional iuse::toolmod_attach( Character *p, item *it, const tripoint return 0; } -std::optional iuse::bell( Character *p, item *it, const tripoint & ) +std::optional iuse::bell( Character *p, item *it, const tripoint_bub_ms & ) { if( it->typeId() == itype_cow_bell ) { sounds::sound( p->pos(), 12, sounds::sound_t::music, _( "Clank! Clank!" ), true, "misc", @@ -5415,7 +5411,7 @@ std::optional iuse::bell( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::seed( Character *p, item *it, const tripoint & ) +std::optional iuse::seed( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_npc() || query_yn( _( "Are you sure you want to eat the %s? You could plant it in a mound of dirt." ), @@ -5433,7 +5429,7 @@ bool iuse::robotcontrol_can_target( Character *p, const monster &m ) && rl_dist( p->pos(), m.pos() ) <= 10; } -std::optional iuse::robotcontrol( Character *p, item *it, const tripoint & ) +std::optional iuse::robotcontrol( Character *p, item *it, const tripoint_bub_ms & ) { bool isComputer = !it->has_flag( flag_MAGICAL ); @@ -5490,9 +5486,9 @@ std::optional iuse::robotcontrol( Character *p, item *it, const tripoint & tripoint seen_loc; // Show locations of seen robots, center on player if robot is not seen if( p->sees( candidate ) ) { - seen_loc = candidate.pos(); + seen_loc = candidate.pos_bub().raw(); } else { - seen_loc = p->pos(); + seen_loc = p->pos_bub().raw(); } locations.push_back( seen_loc ); } @@ -5599,7 +5595,7 @@ void item::extended_photo_def::serialize( JsonOut &jsout ) const jsout.end_object(); } -std::optional iuse::epic_music( Character *p, item *it, const tripoint &pos ) +std::optional iuse::epic_music( Character *p, item *it, const tripoint_bub_ms &pos ) { if( !it->get_var( "EIPC_MUSIC_ON" ).empty() && it->ammo_sufficient( p ) ) { @@ -5611,7 +5607,7 @@ std::optional iuse::epic_music( Character *p, item *it, const tripoint &pos return std::nullopt; } -std::optional iuse::einktabletpc( Character *p, item *it, const tripoint & ) +std::optional iuse::einktabletpc( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { @@ -5713,7 +5709,7 @@ std::optional iuse::einktabletpc( Character *p, item *it, const tripoint & if( it->is_transformable() ) { const use_function *readinglight = it->type->get_use( "transform" ); if( readinglight ) { - readinglight->call( p, *it, p->pos() ); + readinglight->call( p, *it, p->pos_bub() ); } } it->activate(); @@ -5830,7 +5826,7 @@ std::optional iuse::einktabletpc( Character *p, item *it, const tripoint & return std::nullopt; } -static std::string colorized_trap_name_at( const tripoint &point ) +static std::string colorized_trap_name_at( const tripoint_bub_ms &point ) { const trap &trap = get_map().tr_at( point ); std::string name; @@ -5848,7 +5844,7 @@ static const std::unordered_map description_affi { description_affix::DESCRIPTION_AFFIX_ILLUMINATED_BY, translate_marker( " in %s" ) }, }; -static std::string colorized_field_description_at( const tripoint &point ) +static std::string colorized_field_description_at( const tripoint_bub_ms &point ) { std::string field_text; const field &field = get_map().field_at( point ); @@ -5879,7 +5875,7 @@ static std::string colorized_item_description( const item &item ) return item.info( dummy, &query, 1 ); } -static item get_top_item_at_point( const tripoint &point, +static item get_top_item_at_point( const tripoint_bub_ms &point, const units::volume &min_visible_volume ) { map_stack items = get_map().i_at( point ); @@ -5893,7 +5889,7 @@ static item get_top_item_at_point( const tripoint &point, return item(); } -static std::string colorized_ter_name_flags_at( const tripoint &point, +static std::string colorized_ter_name_flags_at( const tripoint_bub_ms &point, const std::vector &flags, const std::vector &ter_whitelist ) { map &here = get_map(); @@ -5928,7 +5924,8 @@ static std::string colorized_ter_name_flags_at( const tripoint &point, return std::string(); } -static std::string colorized_feature_description_at( const tripoint ¢er_point, bool &item_found, +static std::string colorized_feature_description_at( const tripoint_bub_ms ¢er_point, + bool &item_found, const units::volume &min_visible_volume ) { item_found = false; @@ -6073,16 +6070,16 @@ struct object_names_collection { std::string obj_nearby_text; }; -static object_names_collection enumerate_objects_around_point( const tripoint &point, - const int radius, const tripoint &bounds_center_point, const int bounds_radius, - const tripoint &camera_pos, const units::volume &min_visible_volume, bool create_figure_desc, - std::unordered_set &ignored_points, +static object_names_collection enumerate_objects_around_point( const tripoint_bub_ms &point, + const int radius, const tripoint_bub_ms &bounds_center_point, const int bounds_radius, + const tripoint_bub_ms &camera_pos, const units::volume &min_visible_volume, bool create_figure_desc, + std::unordered_set &ignored_points, std::unordered_set &vehicles_recorded ) { map &here = get_map(); - const tripoint_range bounds = + const tripoint_range bounds = here.points_in_radius( bounds_center_point, bounds_radius ); - const tripoint_range points_in_radius = here.points_in_radius( point, radius ); + const tripoint_range points_in_radius = here.points_in_radius( point, radius ); int dist = rl_dist( camera_pos, point ); bool item_found = false; @@ -6094,7 +6091,7 @@ static object_names_collection enumerate_objects_around_point( const tripoint &p std::string description_terrain_on_figure; // store objects in radius - for( const tripoint &point_around_figure : points_in_radius ) { + for( const tripoint_bub_ms &point_around_figure : points_in_radius ) { if( !bounds.is_point_inside( point_around_figure ) || !here.sees( camera_pos, point_around_figure, dist + radius ) || ( ignored_points.find( point_around_figure ) != ignored_points.end() && @@ -6222,14 +6219,14 @@ static object_names_collection enumerate_objects_around_point( const tripoint &p return ret_obj; } -static item::extended_photo_def photo_def_for_camera_point( const tripoint &aim_point, - const tripoint &camera_pos, +static item::extended_photo_def photo_def_for_camera_point( const tripoint_bub_ms &aim_point, + const tripoint_bub_ms &camera_pos, std::vector &monster_vec, std::vector &character_vec ) { // look for big items on top of stacks in the background for the selfie description const units::volume min_visible_volume = 490_ml; - std::unordered_set ignored_points; + std::unordered_set ignored_points; std::unordered_set vehicles_recorded; std::unordered_map description_figures_appearance; @@ -6238,7 +6235,7 @@ static item::extended_photo_def photo_def_for_camera_point( const tripoint &aim_ std::string timestamp = to_string( time_point( calendar::turn ) ); int dist = rl_dist( camera_pos, aim_point ); map &here = get_map(); - const tripoint_range bounds = here.points_in_radius( aim_point, 2 ); + const tripoint_range bounds = here.points_in_radius( aim_point, 2 ); item::extended_photo_def photo; bool need_store_weather = false; int outside_tiles_num = 0; @@ -6256,7 +6253,7 @@ static item::extended_photo_def photo_def_for_camera_point( const tripoint &aim_ creature_tracker &creatures = get_creature_tracker(); // first scan for critters and mark nearby furniture, vehicles and items - for( const tripoint ¤t : bounds ) { + for( const tripoint_bub_ms ¤t : bounds ) { if( !here.sees( camera_pos, current, dist + 3 ) ) { continue; // disallow photos with non-visible objects } @@ -6447,7 +6444,6 @@ static item::extended_photo_def photo_def_for_camera_point( const tripoint &aim_ obj_list ); } - // TODO: fix point types tripoint_abs_omt omp( coords::project_to( here.getglobal( aim_point ) ) ); const oter_id &cur_ter = overmap_buffer.ter( omp ); om_vision_level vision = overmap_buffer.seen( omp ); @@ -6631,7 +6627,7 @@ static bool show_photo_selection( Character &p, item &it, const std::string &var return true; } -std::optional iuse::camera( Character *p, item *it, const tripoint & ) +std::optional iuse::camera( Character *p, item *it, const tripoint_bub_ms & ) { enum {c_shot, c_photos, c_monsters, c_upload}; @@ -6678,24 +6674,24 @@ std::optional iuse::camera( Character *p, item *it, const tripoint & ) p->add_msg_if_player( _( "Never mind." ) ); return std::nullopt; } - tripoint aim_point = *aim_point_; + tripoint_bub_ms aim_point{ *aim_point_ }; bool incorrect_focus = false; - tripoint_range aim_bounds = here.points_in_radius( aim_point, 2 ); + tripoint_range aim_bounds = here.points_in_radius( aim_point, 2 ); - std::vector trajectory = line_to( p->pos(), aim_point, 0, 0 ); + std::vector trajectory = line_to( p->pos_bub(), aim_point, 0, 0 ); trajectory.push_back( aim_point ); p->mod_moves( -to_moves( 1_seconds ) * 0.5 ); sounds::sound( p->pos(), 8, sounds::sound_t::activity, _( "Click." ), true, "tool", "camera_shutter" ); - for( std::vector::iterator point_it = trajectory.begin(); + for( std::vector::iterator point_it = trajectory.begin(); point_it != trajectory.end(); ++point_it ) { - const tripoint trajectory_point = *point_it; + const tripoint_bub_ms trajectory_point = *point_it; if( point_it != trajectory.end() ) { - const tripoint next_point = *( point_it + 1 ); // Trajectory ends on last visible tile - if( !here.sees( p->pos(), next_point, rl_dist( p->pos(), next_point ) + 3 ) ) { + const tripoint_bub_ms next_point = *( point_it + 1 ); // Trajectory ends on last visible tile + if( !here.sees( p->pos_bub(), next_point, rl_dist( p->pos_bub(), next_point ) + 3 ) ) { p->add_msg_if_player( _( "You have the wrong camera focus." ) ); incorrect_focus = true; // recalculate target point @@ -6707,7 +6703,7 @@ std::optional iuse::camera( Character *p, item *it, const tripoint & ) monster *const mon = creatures.creature_at( trajectory_point, true ); Character *const guy = creatures.creature_at( trajectory_point ); if( mon || guy || trajectory_point == aim_point ) { - int dist = rl_dist( p->pos(), trajectory_point ); + int dist = rl_dist( p->pos_bub(), trajectory_point ); int camera_bonus = it->has_flag( flag_CAMERA_PRO ) ? 10 : 0; int photo_quality = 20 - rng( dist, dist * 2 ) * 2 + rng( camera_bonus / 2, camera_bonus ); @@ -6760,7 +6756,7 @@ std::optional iuse::camera( Character *p, item *it, const tripoint & ) std::vector extended_photos; std::vector monster_vec; std::vector character_vec; - item::extended_photo_def photo = photo_def_for_camera_point( trajectory_point, p->pos(), + item::extended_photo_def photo = photo_def_for_camera_point( trajectory_point, p->pos_bub(), monster_vec, character_vec ); photo.quality = photo_quality; @@ -6916,7 +6912,7 @@ std::optional iuse::camera( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::ehandcuffs_tick( Character *p, item *it, const tripoint &pos ) +std::optional iuse::ehandcuffs_tick( Character *p, item *it, const tripoint_bub_ms &pos ) { if( get_map().has_flag( ter_furn_flag::TFLAG_SWIMMABLE, pos.xy() ) ) { @@ -6965,10 +6961,10 @@ std::optional iuse::ehandcuffs_tick( Character *p, item *it, const tripoint "environment", "police_siren" ); } - const point p2( it->get_var( "HANDCUFFS_X", 0 ), it->get_var( "HANDCUFFS_Y", 0 ) ); + const point_bub_ms p2( it->get_var( "HANDCUFFS_X", 0 ), it->get_var( "HANDCUFFS_Y", 0 ) ); - if( ( it->ammo_remaining() > it->type->maximum_charges() - 1000 ) && ( p2.x != pos.x || - p2.y != pos.y ) ) { + if( ( it->ammo_remaining() > it->type->maximum_charges() - 1000 ) && ( p2.x() != pos.x() || + p2.y() != pos.y() ) ) { if( p->is_elec_immune() ) { if( one_in( 10 ) ) { @@ -6988,8 +6984,8 @@ std::optional iuse::ehandcuffs_tick( Character *p, item *it, const tripoint it->charges = 1; } - it->set_var( "HANDCUFFS_X", pos.x ); - it->set_var( "HANDCUFFS_Y", pos.y ); + it->set_var( "HANDCUFFS_X", pos.x() ); + it->set_var( "HANDCUFFS_Y", pos.y() ); return 1; @@ -6998,7 +6994,7 @@ std::optional iuse::ehandcuffs_tick( Character *p, item *it, const tripoint return 1; } -std::optional iuse::ehandcuffs( Character *, item *it, const tripoint & ) +std::optional iuse::ehandcuffs( Character *, item *it, const tripoint_bub_ms & ) { if( it->active ) { add_msg( _( "The %s are clamped tightly on your wrists. You can't take them off." ), @@ -7010,18 +7006,18 @@ std::optional iuse::ehandcuffs( Character *, item *it, const tripoint & ) return 1; } -std::optional iuse::afs_translocator( Character *p, item *it, const tripoint & ) +std::optional iuse::afs_translocator( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->ammo_sufficient( p ) ) { return std::nullopt; } - const std::optional dest_ = choose_adjacent( _( "Create buoy where?" ) ); + const std::optional dest_ = choose_adjacent_bub( _( "Create buoy where?" ) ); if( !dest_ ) { return std::nullopt; } - tripoint dest = *dest_; + tripoint_bub_ms dest = *dest_; p->mod_moves( -to_moves( 2_seconds ) ); @@ -7038,7 +7034,7 @@ std::optional iuse::afs_translocator( Character *p, item *it, const tripoin } } -std::optional iuse::foodperson_voice( Character *, item *, const tripoint &pos ) +std::optional iuse::foodperson_voice( Character *, item *, const tripoint_bub_ms &pos ) { if( calendar::once_every( 1_minutes ) ) { const SpeechBubble &speech = get_speech( "foodperson_mask" ); @@ -7048,7 +7044,7 @@ std::optional iuse::foodperson_voice( Character *, item *, const tripoint & return 0; } -std::optional iuse::foodperson( Character *p, item *it, const tripoint & ) +std::optional iuse::foodperson( Character *p, item *it, const tripoint_bub_ms & ) { // Prevent crash if battery was somehow removed. if( !it->magazine_current() ) { @@ -7063,7 +7059,7 @@ std::optional iuse::foodperson( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::radiocar( Character *p, item *it, const tripoint & ) +std::optional iuse::radiocar( Character *p, item *it, const tripoint_bub_ms & ) { int choice = -1; item *bomb_it = it->get_item_with( []( const item & c ) { @@ -7140,7 +7136,7 @@ std::optional iuse::radiocar( Character *p, item *it, const tripoint & ) return 1; } -std::optional iuse::radiocaron( Character *p, item *it, const tripoint & ) +std::optional iuse::radiocaron( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->ammo_sufficient( p ) ) { // Deactivate since other mode has an iuse too. @@ -7181,7 +7177,7 @@ static void sendRadioSignal( Character &p, const flag_id &signal ) std::map use_methods = it.type->use_methods; if( use_methods.find( "transform" ) != use_methods.end() ) { it.type->get_use( "transform" )->call( &p, it, loc ); - item_location itm_loc = item_location( map_cursor( tripoint_bub_ms( loc ) ), &it ); + item_location itm_loc = item_location( map_cursor( loc ), &it ); here.update_lum( itm_loc, true ); } else { it.type->get_use( it.type->use_methods.begin()->first )->call( &p, it, loc ); @@ -7197,7 +7193,7 @@ static void sendRadioSignal( Character &p, const flag_id &signal ) // Invoke to transform a radio-modded explosive into its active form if( itm->has_flag( flag_RADIO_INVOKE_PROC ) ) { itm->type->invoke( &p, *itm, loc.raw() ); - item_location itm_loc = item_location( map_cursor( tripoint_bub_ms( loc ) ), itm ); + item_location itm_loc = item_location( map_cursor( loc ), itm ); here.update_lum( itm_loc, true ); } } @@ -7206,7 +7202,7 @@ static void sendRadioSignal( Character &p, const flag_id &signal ) } } -std::optional iuse::radiocontrol_tick( Character *p, item *it, const tripoint & ) +std::optional iuse::radiocontrol_tick( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { // Player has dropped the controller @@ -7225,7 +7221,7 @@ std::optional iuse::radiocontrol_tick( Character *p, item *it, const tripoi return 1; } -std::optional iuse::radiocontrol( Character *p, item *it, const tripoint & ) +std::optional iuse::radiocontrol( Character *p, item *it, const tripoint_bub_ms & ) { const char *car_action = nullptr; @@ -7366,7 +7362,7 @@ static bool hackveh( Character &p, item &it, vehicle &veh ) return success; } -static vehicle *pickveh( const tripoint ¢er, bool advanced ) +static vehicle *pickveh( const tripoint_bub_ms ¢er, bool advanced ) { static const std::string ctrl = "CTRL_ELECTRONIC"; static const std::string advctrl = "REMOTE_CONTROLS"; @@ -7376,7 +7372,7 @@ static vehicle *pickveh( const tripoint ¢er, bool advanced ) for( wrapped_vehicle &veh : get_map().get_vehicles() ) { vehicle *&v = veh.v; - if( rl_dist( center, v->pos_bub().raw() ) < 40 && + if( rl_dist( center, v->pos_bub() ) < 40 && v->fuel_left( itype_battery ) > 0 && ( !empty( v->get_avail_parts( advctrl ) ) || ( !advanced && !empty( v->get_avail_parts( ctrl ) ) ) ) ) { @@ -7409,7 +7405,7 @@ static vehicle *pickveh( const tripoint ¢er, bool advanced ) } } -std::optional iuse::remoteveh_tick( Character *p, item *it, const tripoint & ) +std::optional iuse::remoteveh_tick( Character *p, item *it, const tripoint_bub_ms & ) { vehicle *remote = g->remoteveh(); bool stop = false; @@ -7431,7 +7427,7 @@ std::optional iuse::remoteveh_tick( Character *p, item *it, const tripoint return 1; } -std::optional iuse::remoteveh( Character *p, item *it, const tripoint &pos ) +std::optional iuse::remoteveh( Character *p, item *it, const tripoint_bub_ms &pos ) { vehicle *remote = g->remoteveh(); @@ -7543,9 +7539,8 @@ static bool multicooker_hallu( Character &p ) } -std::optional iuse::multicooker( Character *p, item *it, const tripoint &pos ) +std::optional iuse::multicooker( Character *p, item *it, const tripoint_bub_ms &pos ) { - const tripoint_bub_ms position{pos}; // TODO: Get rid of this when operation typified. static const int charges_to_start = 50; const int charge_buffer = 2; @@ -7754,7 +7749,7 @@ std::optional iuse::multicooker( Character *p, item *it, const tripoint &po _( "The screen flashes blue symbols and scales as the multi-cooker begins to shake." ) ); it->convert( itype_multi_cooker_filled, p ).active = true; - it->ammo_consume( charges_to_start - charge_buffer, position, p ); + it->ammo_consume( charges_to_start - charge_buffer, pos, p ); p->practice( skill_cooking, meal->difficulty * 3 ); //little bonus @@ -7832,9 +7827,8 @@ std::optional iuse::multicooker( Character *p, item *it, const tripoint &po return 0; } -std::optional iuse::multicooker_tick( Character *p, item *it, const tripoint &pos ) +std::optional iuse::multicooker_tick( Character *p, item *it, const tripoint_bub_ms &pos ) { - const tripoint_bub_ms position{pos}; // TODO: Get rid of this when operation typified. const int charge_buffer = 2; //stop action before power runs out and iuse deletes the cooker @@ -7843,7 +7837,7 @@ std::optional iuse::multicooker_tick( Character *p, item *it, const tripoin it->erase_var( "RECIPE" ); it->convert( itype_multi_cooker, p ); //drain the buffer amount given at activation - it->ammo_consume( charge_buffer, position, p ); + it->ammo_consume( charge_buffer, pos, p ); p->add_msg_if_player( m_info, _( "Batteries low, entering standby mode. With a low buzzing sound the multi-cooker shuts down." ) ); return 0; @@ -7870,7 +7864,7 @@ std::optional iuse::multicooker_tick( Character *p, item *it, const tripoin meal.heat_up(); } else { meal.set_item_temperature( std::max( temperatures::cold, - get_weather().get_temperature( position.raw() ) ) ); + get_weather().get_temperature( pos.raw() ) ) ); } it->active = false; @@ -7885,7 +7879,7 @@ std::optional iuse::multicooker_tick( Character *p, item *it, const tripoin } //~ sound of a multi-cooker finishing its cycle! - sounds::sound( position, 8, sounds::sound_t::alarm, _( "ding!" ), true, "misc", "ding" ); + sounds::sound( pos, 8, sounds::sound_t::alarm, _( "ding!" ), true, "misc", "ding" ); return 0; } else { @@ -7896,7 +7890,7 @@ std::optional iuse::multicooker_tick( Character *p, item *it, const tripoin return 0; } -std::optional iuse::weather_tool( Character *p, item *it, const tripoint & ) +std::optional iuse::weather_tool( Character *p, item *it, const tripoint_bub_ms & ) { weather_manager &weather = get_weather(); const w_point weatherPoint = *weather.weather_precise; @@ -7966,7 +7960,7 @@ std::optional iuse::weather_tool( Character *p, item *it, const tripoint & return 1; //TODO check } -std::optional iuse::sextant( Character *p, item *, const tripoint &pos ) +std::optional iuse::sextant( Character *p, item *, const tripoint_bub_ms &pos ) { const std::pair sun_position = sun_azimuth_altitude( calendar::turn ); const float altitude = to_degrees( sun_position.second ); @@ -7985,20 +7979,20 @@ std::optional iuse::sextant( Character *p, item *, const tripoint &pos ) return 0; } -std::optional iuse::lux_meter( Character *p, item *it, const tripoint &pos ) +std::optional iuse::lux_meter( Character *p, item *it, const tripoint_bub_ms &pos ) { p->add_msg_if_player( m_neutral, _( "The illumination is %.1f." ), - g->natural_light_level( pos.z ) ); + g->natural_light_level( pos.z() ) ); return it->type->charges_to_use(); } -std::optional iuse::dbg_lux_meter( Character *p, item *, const tripoint &pos ) +std::optional iuse::dbg_lux_meter( Character *p, item *, const tripoint_bub_ms &pos ) { map &here = get_map(); const float incident_light = incident_sunlight( current_weather( here.getglobal( pos ) ), calendar::turn ); - const float nat_light = g->natural_light_level( pos.z ); + const float nat_light = g->natural_light_level( pos.z() ); const float sunlight = sun_light_at( calendar::turn ); const float sun_irrad = sun_irradiance( calendar::turn ); const float incident_irrad = incident_sun_irradiance( current_weather( here.getglobal( pos ) ), @@ -8010,7 +8004,7 @@ std::optional iuse::dbg_lux_meter( Character *p, item *, const tripoint &po return 0; } -std::optional iuse::calories_intake_tracker( Character *p, item *it, const tripoint & ) +std::optional iuse::calories_intake_tracker( Character *p, item *it, const tripoint_bub_ms & ) { if( p->has_trait( trait_ILLITERATE ) ) { p->add_msg_if_player( m_info, _( "You don't know what you're looking at." ) ); @@ -8031,18 +8025,19 @@ std::optional iuse::calories_intake_tracker( Character *p, item *it, const return 1; } -std::optional iuse::directional_hologram( Character *p, item *it, const tripoint & ) +std::optional iuse::directional_hologram( Character *p, item *it, const tripoint_bub_ms & ) { if( it->is_armor() && !p->is_worn( *it ) ) { p->add_msg_if_player( m_neutral, _( "You need to wear the %1$s before activating it." ), it->tname() ); return std::nullopt; } - const std::optional posp = choose_adjacent( _( "Choose hologram direction." ) ); + const std::optional posp = choose_adjacent_bub( + _( "Choose hologram direction." ) ); if( !posp ) { return std::nullopt; } - const tripoint delta = *posp - get_player_character().pos(); + const tripoint_rel_ms delta = *posp - get_player_character().pos_bub(); monster *const hologram = g->place_critter_at( mon_hologram, *posp ); if( !hologram ) { @@ -8059,7 +8054,7 @@ std::optional iuse::directional_hologram( Character *p, item *it, const tri return 1; } -std::optional iuse::capture_monster_veh( Character *p, item *it, const tripoint &pos ) +std::optional iuse::capture_monster_veh( Character *p, item *it, const tripoint_bub_ms &pos ) { if( p->cant_do_mounted() ) { return std::nullopt; @@ -8112,9 +8107,8 @@ int item::contain_monster( const tripoint_bub_ms &target ) return 0; } -std::optional iuse::capture_monster_act( Character *p, item *it, const tripoint &pos ) +std::optional iuse::capture_monster_act( Character *p, item *it, const tripoint_bub_ms &pos ) { - const tripoint_bub_ms position{ pos }; // TODO: Get rid of this when typing operation. if( p->is_mounted() ) { p->add_msg_if_player( m_info, _( "You can't capture a creature mounted." ) ); return std::nullopt; @@ -8123,7 +8117,7 @@ std::optional iuse::capture_monster_act( Character *p, item *it, const trip // Remember contained_name for messages after release_monster erases it const std::string contained_name = it->get_var( "contained_name", "" ); - if( it->release_monster( position ) ) { + if( it->release_monster( pos ) ) { p->invalidate_weight_carried_cache(); // It's been activated somewhere where there isn't a player or monster, good. return 0; @@ -8463,7 +8457,7 @@ static bool heat_items( Character *p, item *it, bool liquid_items, bool solid_it return true; } -std::optional iuse::heat_solid_items( Character *p, item *it, const tripoint & ) +std::optional iuse::heat_solid_items( Character *p, item *it, const tripoint_bub_ms & ) { if( p->fine_detail_vision_mod() > 4 ) { p->add_msg_if_player( _( "You can't see to do that!" ) ); @@ -8483,7 +8477,7 @@ std::optional iuse::heat_solid_items( Character *p, item *it, const tripoin return std::nullopt; } -std::optional iuse::heat_liquid_items( Character *p, item *it, const tripoint & ) +std::optional iuse::heat_liquid_items( Character *p, item *it, const tripoint_bub_ms & ) { if( p->fine_detail_vision_mod() > 4 ) { p->add_msg_if_player( _( "You can't see to do that!" ) ); @@ -8503,7 +8497,7 @@ std::optional iuse::heat_liquid_items( Character *p, item *it, const tripoi return std::nullopt; } -std::optional iuse::heat_all_items( Character *p, item *it, const tripoint & ) +std::optional iuse::heat_all_items( Character *p, item *it, const tripoint_bub_ms & ) { if( p->fine_detail_vision_mod() > 4 ) { p->add_msg_if_player( _( "You can't see to do that!" ) ); @@ -8531,7 +8525,7 @@ washing_requirements washing_requirements_for_volume( const units::volume &vol ) return { water, cleanser, time }; } -std::optional iuse::wash_soft_items( Character *p, item *, const tripoint & ) +std::optional iuse::wash_soft_items( Character *p, item *, const tripoint_bub_ms & ) { if( p->fine_detail_vision_mod() > 4 ) { p->add_msg_if_player( _( "You can't see to do that!" ) ); @@ -8551,7 +8545,7 @@ std::optional iuse::wash_soft_items( Character *p, item *, const tripoint & return 0; } -std::optional iuse::wash_hard_items( Character *p, item *, const tripoint & ) +std::optional iuse::wash_hard_items( Character *p, item *, const tripoint_bub_ms & ) { if( p->fine_detail_vision_mod() > 4 ) { p->add_msg_if_player( _( "You can't see to do that!" ) ); @@ -8571,7 +8565,7 @@ std::optional iuse::wash_hard_items( Character *p, item *, const tripoint & return 0; } -std::optional iuse::wash_all_items( Character *p, item *, const tripoint & ) +std::optional iuse::wash_all_items( Character *p, item *, const tripoint_bub_ms & ) { if( p->fine_detail_vision_mod() > 4 ) { p->add_msg_if_player( _( "You can't see to do that!" ) ); @@ -8690,7 +8684,7 @@ std::optional iuse::wash_items( Character *p, bool soft_items, bool hard_it return 0; } -std::optional iuse::break_stick( Character *p, item *it, const tripoint & ) +std::optional iuse::break_stick( Character *p, item *it, const tripoint_bub_ms & ) { p->mod_moves( -to_moves( 2_seconds ) ); p->mod_stamina( static_cast( 0.05f * p->get_stamina_max() ) ); @@ -8725,7 +8719,7 @@ std::optional iuse::break_stick( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::weak_antibiotic( Character *p, item *it, const tripoint & ) +std::optional iuse::weak_antibiotic( Character *p, item *it, const tripoint_bub_ms & ) { p->add_msg_if_player( _( "You take some %s." ), it->tname() ); if( p->has_effect( effect_infected ) && !p->has_effect( effect_weak_antibiotic ) ) { @@ -8736,7 +8730,7 @@ std::optional iuse::weak_antibiotic( Character *p, item *it, const tripoint return 1; } -std::optional iuse::strong_antibiotic( Character *p, item *it, const tripoint & ) +std::optional iuse::strong_antibiotic( Character *p, item *it, const tripoint_bub_ms & ) { p->add_msg_if_player( _( "You take some %s." ), it->tname() ); if( p->has_effect( effect_infected ) && !p->has_effect( effect_strong_antibiotic ) ) { @@ -8766,7 +8760,7 @@ static item *wield_before_use( Character *const p, item *const it, const std::st return it; } -std::optional iuse::craft( Character *p, item *it, const tripoint & ) +std::optional iuse::craft( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { return std::nullopt; @@ -8803,7 +8797,7 @@ std::optional iuse::craft( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::disassemble( Character *p, item *it, const tripoint & ) +std::optional iuse::disassemble( Character *p, item *it, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { return std::nullopt; @@ -8821,7 +8815,7 @@ std::optional iuse::disassemble( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::post_up( Character *p, item *it, const tripoint & ) +std::optional iuse::post_up( Character *p, item *it, const tripoint_bub_ms & ) { map &here = get_map(); @@ -8846,7 +8840,7 @@ std::optional iuse::post_up( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::melatonin_tablet( Character *p, item *it, const tripoint & ) +std::optional iuse::melatonin_tablet( Character *p, item *it, const tripoint_bub_ms & ) { p->add_msg_if_player( _( "You pop a %s." ), it->tname() ); if( p->has_effect( effect_melatonin ) ) { @@ -8857,14 +8851,14 @@ std::optional iuse::melatonin_tablet( Character *p, item *it, const tripoin return 1; } -std::optional iuse::coin_flip( Character *p, item *it, const tripoint & ) +std::optional iuse::coin_flip( Character *p, item *it, const tripoint_bub_ms & ) { p->add_msg_if_player( m_info, _( "You flip a %s." ), it->tname() ); p->add_msg_if_player( m_info, one_in( 2 ) ? _( "Heads!" ) : _( "Tails!" ) ); return 0; } -std::optional iuse::play_game( Character *p, item *it, const tripoint & ) +std::optional iuse::play_game( Character *p, item *it, const tripoint_bub_ms & ) { if( p->is_avatar() ) { std::vector followers = g->get_npcs_if( [p]( const npc & n ) { @@ -8912,7 +8906,7 @@ std::optional iuse::play_game( Character *p, item *it, const tripoint & ) return 0; } -std::optional iuse::magic_8_ball( Character *p, item *it, const tripoint & ) +std::optional iuse::magic_8_ball( Character *p, item *it, const tripoint_bub_ms & ) { p->add_msg_if_player( m_info, _( "You ask the %s, then flip it." ), it->tname() ); int rn = rng( 0, 3 ); @@ -8933,7 +8927,7 @@ std::optional iuse::magic_8_ball( Character *p, item *it, const tripoint & return 0; } -std::optional iuse::measure_resonance( Character *p, item *it, const tripoint & ) +std::optional iuse::measure_resonance( Character *p, item *it, const tripoint_bub_ms & ) { if( !it->ammo_sufficient( p ) ) { popup( _( "The device doesn't have enough power to function!" ) ); @@ -8999,7 +8993,7 @@ std::optional iuse::measure_resonance( Character *p, item *it, const tripoi return 0; } -std::optional iuse::change_outfit( Character *p, item *it, const tripoint & ) +std::optional iuse::change_outfit( Character *p, item *it, const tripoint_bub_ms & ) { if( !p->is_avatar() ) { debugmsg( "NPC %s tried to swap outfit", p->get_name() ); @@ -9012,7 +9006,7 @@ std::optional iuse::change_outfit( Character *p, item *it, const tripoint & return std::nullopt; } -std::optional iuse::electricstorage( Character *p, item *it, const tripoint & ) +std::optional iuse::electricstorage( Character *p, item *it, const tripoint_bub_ms & ) { // From item processing if( !p ) { @@ -9140,7 +9134,7 @@ std::optional iuse::electricstorage( Character *p, item *it, const tripoint return std::nullopt; } -std::optional iuse::ebooksave( Character *p, item *it, const tripoint & ) +std::optional iuse::ebooksave( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action ebooksave that requires character but no character is present", @@ -9187,7 +9181,7 @@ std::optional iuse::ebooksave( Character *p, item *it, const tripoint & ) return std::nullopt; } -std::optional iuse::ebookread( Character *p, item *it, const tripoint & ) +std::optional iuse::ebookread( Character *p, item *it, const tripoint_bub_ms & ) { if( !p ) { debugmsg( "%s called action ebookread that requires character but no character is present", @@ -9220,7 +9214,7 @@ std::optional iuse::ebookread( Character *p, item *it, const tripoint & ) if( p->fine_detail_vision_mod() > 4 && !it->active && it->is_transformable() ) { const use_function *readinglight = it->type->get_use( "transform" ); if( readinglight ) { - readinglight->call( p, *it, p->pos() ); + readinglight->call( p, *it, p->pos_bub() ); } } @@ -9236,7 +9230,7 @@ std::optional iuse::ebookread( Character *p, item *it, const tripoint & ) return std::nullopt; } -std::optional iuse::binder_add_recipe( Character *p, item *binder, const tripoint & ) +std::optional iuse::binder_add_recipe( Character *p, item *binder, const tripoint_bub_ms & ) { if( p->cant_do_mounted() ) { return std::nullopt; @@ -9313,9 +9307,8 @@ std::optional iuse::binder_add_recipe( Character *p, item *binder, const tr } std::optional iuse::binder_manage_recipe( Character *p, item *binder, - const tripoint &ipos ) + const tripoint_bub_ms &ipos ) { - const tripoint_bub_ms pos{ ipos }; // TODO: Get rid of this when operation typified. if( p->is_underwater() ) { p->add_msg_if_player( m_info, _( "Doing that would ruin the %1$s." ), binder->tname() ); return std::nullopt; @@ -9355,14 +9348,14 @@ std::optional iuse::binder_manage_recipe( Character *p, item *binder, binder->set_saved_recipes( binder_recipes ); const int pages = bookbinder_copy_activity_actor::pages_for_recipe( *rec ); - binder->ammo_consume( pages, pos, p ); + binder->ammo_consume( pages, ipos, p ); return std::nullopt; } -std::optional iuse::voltmeter( Character *p, item *, const tripoint & ) +std::optional iuse::voltmeter( Character *p, item *, const tripoint_bub_ms & ) { - const std::optional pnt_ = choose_adjacent( _( "Check voltage where?" ) ); + const std::optional pnt_ = choose_adjacent_bub( _( "Check voltage where?" ) ); if( !pnt_ ) { return std::nullopt; } @@ -9390,7 +9383,7 @@ void use_function::dump_info( const item &it, std::vector &dump ) cons } ret_val use_function::can_call( const Character &p, const item &it, - const tripoint &pos ) const + const tripoint_bub_ms &pos ) const { if( actor == nullptr ) { return ret_val::make_failure( _( "You can't do anything interesting with your %s." ), @@ -9403,14 +9396,8 @@ ret_val use_function::can_call( const Character &p, const item &it, return actor->can_use( p, it, pos ); } -std::optional use_function::call( Character *p, item &it, - const tripoint &pos ) const -{ - return actor->use( p, it, pos ); -} - std::optional use_function::call( Character *p, item &it, const tripoint_bub_ms &pos ) const { - return use_function::call( p, it, pos.raw() ); + return actor->use( p, it, pos ); } diff --git a/src/iuse.h b/src/iuse.h index 5f523e7e9847b..989e869c121f5 100644 --- a/src/iuse.h +++ b/src/iuse.h @@ -9,6 +9,7 @@ #include #include "clone_ptr.h" +#include "coords_fwd.h" #include "item_location.h" #include "type_id.h" #include "units_fwd.h" @@ -18,7 +19,6 @@ class JsonObject; class item; class monster; struct iteminfo; -struct tripoint; template class ret_val; // iuse methods return the number of charges expended, which is usually "1", or no value. @@ -30,203 +30,203 @@ namespace iuse { // FOOD AND DRUGS (ADMINISTRATION) -std::optional alcohol_medium( Character *, item *, const tripoint & ); -std::optional alcohol_strong( Character *, item *, const tripoint & ); -std::optional alcohol_weak( Character *, item *, const tripoint & ); -std::optional antibiotic( Character *, item *, const tripoint & ); -std::optional anticonvulsant( Character *, item *, const tripoint & ); -std::optional antifungal( Character *, item *, const tripoint & ); -std::optional antiparasitic( Character *, item *, const tripoint & ); -std::optional blech( Character *, item *, const tripoint & ); -std::optional blech_because_unclean( Character *, item *, const tripoint & ); -std::optional chew( Character *, item *, const tripoint & ); -std::optional coke( Character *, item *, const tripoint & ); -std::optional datura( Character *, item *, const tripoint & ); -std::optional ecig( Character *, item *, const tripoint & ); -std::optional eyedrops( Character *, item *, const tripoint & ); -std::optional flu_vaccine( Character *, item *, const tripoint & ); -std::optional flumed( Character *, item *, const tripoint & ); -std::optional flusleep( Character *, item *, const tripoint & ); -std::optional fungicide( Character *, item *, const tripoint & ); -std::optional honeycomb( Character *, item *, const tripoint & ); -std::optional inhaler( Character *, item *, const tripoint & ); -std::optional marloss( Character *, item *, const tripoint & ); -std::optional marloss_gel( Character *, item *, const tripoint & ); -std::optional marloss_seed( Character *, item *, const tripoint & ); -std::optional meditate( Character *, item *, const tripoint & ); -std::optional meth( Character *, item *, const tripoint & ); -std::optional mycus( Character *, item *, const tripoint & ); -std::optional petfood( Character *p, item *it, const tripoint & ); -std::optional plantblech( Character *, item *, const tripoint & ); -std::optional poison( Character *, item *, const tripoint & ); -std::optional prozac( Character *, item *, const tripoint & ); -std::optional purify_smart( Character *, item *, const tripoint & ); -std::optional sewage( Character *, item *, const tripoint & ); -std::optional smoking( Character *, item *, const tripoint & ); -std::optional thorazine( Character *, item *, const tripoint & ); -std::optional weed_cake( Character *, item *, const tripoint & ); -std::optional xanax( Character *, item *, const tripoint & ); +std::optional alcohol_medium( Character *, item *, const tripoint_bub_ms & ); +std::optional alcohol_strong( Character *, item *, const tripoint_bub_ms & ); +std::optional alcohol_weak( Character *, item *, const tripoint_bub_ms & ); +std::optional antibiotic( Character *, item *, const tripoint_bub_ms & ); +std::optional anticonvulsant( Character *, item *, const tripoint_bub_ms & ); +std::optional antifungal( Character *, item *, const tripoint_bub_ms & ); +std::optional antiparasitic( Character *, item *, const tripoint_bub_ms & ); +std::optional blech( Character *, item *, const tripoint_bub_ms & ); +std::optional blech_because_unclean( Character *, item *, const tripoint_bub_ms & ); +std::optional chew( Character *, item *, const tripoint_bub_ms & ); +std::optional coke( Character *, item *, const tripoint_bub_ms & ); +std::optional datura( Character *, item *, const tripoint_bub_ms & ); +std::optional ecig( Character *, item *, const tripoint_bub_ms & ); +std::optional eyedrops( Character *, item *, const tripoint_bub_ms & ); +std::optional flu_vaccine( Character *, item *, const tripoint_bub_ms & ); +std::optional flumed( Character *, item *, const tripoint_bub_ms & ); +std::optional flusleep( Character *, item *, const tripoint_bub_ms & ); +std::optional fungicide( Character *, item *, const tripoint_bub_ms & ); +std::optional honeycomb( Character *, item *, const tripoint_bub_ms & ); +std::optional inhaler( Character *, item *, const tripoint_bub_ms & ); +std::optional marloss( Character *, item *, const tripoint_bub_ms & ); +std::optional marloss_gel( Character *, item *, const tripoint_bub_ms & ); +std::optional marloss_seed( Character *, item *, const tripoint_bub_ms & ); +std::optional meditate( Character *, item *, const tripoint_bub_ms & ); +std::optional meth( Character *, item *, const tripoint_bub_ms & ); +std::optional mycus( Character *, item *, const tripoint_bub_ms & ); +std::optional petfood( Character *p, item *it, const tripoint_bub_ms & ); +std::optional plantblech( Character *, item *, const tripoint_bub_ms & ); +std::optional poison( Character *, item *, const tripoint_bub_ms & ); +std::optional prozac( Character *, item *, const tripoint_bub_ms & ); +std::optional purify_smart( Character *, item *, const tripoint_bub_ms & ); +std::optional sewage( Character *, item *, const tripoint_bub_ms & ); +std::optional smoking( Character *, item *, const tripoint_bub_ms & ); +std::optional thorazine( Character *, item *, const tripoint_bub_ms & ); +std::optional weed_cake( Character *, item *, const tripoint_bub_ms & ); +std::optional xanax( Character *, item *, const tripoint_bub_ms & ); // TOOLS -std::optional acidbomb_act( Character *, item *, const tripoint & ); -std::optional adrenaline_injector( Character *, item *, const tripoint & ); -std::optional afs_translocator( Character *, item *, const tripoint & ); -std::optional bell( Character *, item *, const tripoint & ); -std::optional blood_draw( Character *, item *, const tripoint & ); -std::optional boltcutters( Character *, item *, const tripoint & ); -std::optional break_stick( Character *, item *, const tripoint & ); -std::optional c4( Character *, item *, const tripoint & ); -std::optional call_of_tindalos( Character *, item *, const tripoint & ); -std::optional camera( Character *, item *, const tripoint & ); -std::optional can_goo( Character *, item *, const tripoint & ); -std::optional capture_monster_act( Character *, item *, const tripoint & ); -std::optional heat_solid_items( Character *p, item *it, const tripoint & ); -std::optional heat_liquid_items( Character *p, item *it, const tripoint & ); -std::optional heat_all_items( Character *p, item *it, const tripoint & ); -std::optional capture_monster_veh( Character *, item *, const tripoint & ); -std::optional change_eyes( Character *, item *, const tripoint & ); -std::optional change_skin( Character *, item *, const tripoint & ); -std::optional chop_logs( Character *, item *, const tripoint & ); -std::optional chop_tree( Character *, item *, const tripoint & ); -std::optional clear_rubble( Character *, item *, const tripoint & ); -std::optional coin_flip( Character *, item *, const tripoint & ); -std::optional contacts( Character *, item *, const tripoint & ); -std::optional crowbar( Character *, item *, const tripoint & ); -std::optional crowbar_weak( Character *, item *, const tripoint & ); -std::optional dig( Character *, item *, const tripoint & ); -std::optional dig_channel( Character *, item *, const tripoint & ); -std::optional directional_antenna( Character *, item *, const tripoint & ); -std::optional directional_hologram( Character *, item *, const tripoint & ); -std::optional dive_tank_activate( Character *, item *, const tripoint & ); -std::optional dive_tank( Character *, item *, const tripoint & ); -std::optional dog_whistle( Character *, item *, const tripoint & ); -std::optional ehandcuffs( Character *, item *, const tripoint & ); -std::optional ehandcuffs_tick( Character *, item *, const tripoint & ); -std::optional epic_music( Character *, item *, const tripoint & ); -std::optional einktabletpc( Character *, item *, const tripoint & ); -std::optional emf_passive_on( Character *, item *, const tripoint & ); -std::optional extinguisher( Character *, item *, const tripoint & ); -std::optional fill_pit( Character *, item *, const tripoint & ); -std::optional firecracker( Character *, item *, const tripoint & ); -std::optional firecracker_pack( Character *, item *, const tripoint & ); -std::optional firecracker_pack_act( Character *, item *, const tripoint & ); -std::optional fish_trap( Character *, item *, const tripoint & ); -std::optional fish_trap_tick( Character *, item *, const tripoint & ); -std::optional fishing_rod( Character *, item *, const tripoint & ); -std::optional fitness_check( Character *p, item *it, const tripoint & ); -std::optional foodperson( Character *, item *, const tripoint & ); -std::optional foodperson_voice( Character *, item *, const tripoint & ); -std::optional gasmask( Character *, item *, const tripoint & ); -std::optional gasmask_activate( Character *, item *, const tripoint & ); -std::optional geiger( Character *, item *, const tripoint & ); -std::optional geiger_active( Character *, item *, const tripoint & ); -std::optional granade_act( Character *, item *, const tripoint & ); -std::optional grenade_inc_act( Character *, item *, const tripoint & ); -std::optional gun_repair( Character *, item *, const tripoint & ); -std::optional gunmod_attach( Character *, item *, const tripoint & ); -std::optional hacksaw( Character *, item *, const tripoint &it_pnt ); -std::optional hairkit( Character *, item *, const tripoint & ); -std::optional hand_crank( Character *, item *, const tripoint & ); -std::optional heat_food( Character *, item *, const tripoint & ); -std::optional heatpack( Character *, item *, const tripoint & ); -std::optional hotplate( Character *, item *, const tripoint & ); -std::optional hotplate_atomic( Character *, item *, const tripoint & ); -std::optional jackhammer( Character *, item *, const tripoint & ); -std::optional jet_injector( Character *, item *, const tripoint & ); -std::optional lumber( Character *, item *, const tripoint & ); -std::optional ma_manual( Character *, item *, const tripoint & ); -std::optional magic_8_ball( Character *, item *, const tripoint & ); -std::optional measure_resonance( Character *, item *, const tripoint & ); -std::optional change_outfit( Character *, item *, const tripoint & ); -std::optional electricstorage( Character *, item *, const tripoint & ); -std::optional ebooksave( Character *, item *, const tripoint & ); -std::optional ebookread( Character *, item *, const tripoint & ); -std::optional makemound( Character *, item *, const tripoint & ); -std::optional mace( Character *, item *, const tripoint & ); -std::optional manage_exosuit( Character *, item *, const tripoint & ); -std::optional melatonin_tablet( Character *, item *, const tripoint & ); -std::optional mininuke( Character *, item *, const tripoint & ); -std::optional molotov_lit( Character *, item *, const tripoint & ); -std::optional mop( Character *, item *, const tripoint & ); -std::optional mp3( Character *, item *, const tripoint & ); -std::optional mp3_on( Character *, item *, const tripoint & ); -std::optional mp3_deactivate( Character *, item *, const tripoint & ); -std::optional noise_emitter_on( Character *, item *, const tripoint & ); -std::optional oxygen_bottle( Character *, item *, const tripoint & ); -std::optional oxytorch( Character *, item *, const tripoint & ); -std::optional binder_add_recipe( Character *, item *, const tripoint & ); -std::optional binder_manage_recipe( Character *, item *, const tripoint & ); -std::optional pack_cbm( Character *p, item *it, const tripoint & ); -std::optional pack_item( Character *, item *, const tripoint & ); -std::optional pick_lock( Character *p, item *it, const tripoint &pos ); -std::optional pickaxe( Character *, item *, const tripoint & ); -std::optional play_game( Character *, item *, const tripoint & ); -std::optional portable_game( Character *, item *, const tripoint & ); -std::optional portal( Character *, item *, const tripoint & ); -std::optional radglove( Character *, item *, const tripoint & ); -std::optional radio_mod( Character *, item *, const tripoint & ); -std::optional radio_off( Character *, item *, const tripoint & ); -std::optional radio_on( Character *, item *, const tripoint & ); -std::optional radio_tick( Character *, item *, const tripoint & ); -std::optional remove_all_mods( Character *, item *, const tripoint & ); -std::optional robotcontrol( Character *, item *, const tripoint & ); -std::optional rpgdie( Character *, item *, const tripoint & ); -std::optional seed( Character *, item *, const tripoint & ); -std::optional shavekit( Character *, item *, const tripoint & ); -std::optional shocktonfa_off( Character *, item *, const tripoint & ); -std::optional shocktonfa_on( Character *, item *, const tripoint & ); -std::optional siphon( Character *, item *, const tripoint & ); -std::optional solarpack( Character *, item *, const tripoint & ); -std::optional solarpack_off( Character *, item *, const tripoint & ); -std::optional spray_can( Character *, item *, const tripoint & ); -std::optional stimpack( Character *, item *, const tripoint & ); -std::optional strong_antibiotic( Character *, item *, const tripoint & ); -std::optional talking_doll( Character *, item *, const tripoint & ); -std::optional tazer( Character *, item *, const tripoint & ); -std::optional tazer2( Character *, item *, const tripoint & ); -std::optional teleport( Character *, item *, const tripoint & ); -std::optional toolmod_attach( Character *, item *, const tripoint & ); -std::optional towel( Character *, item *, const tripoint & ); -std::optional unfold_generic( Character *, item *, const tripoint & ); -std::optional unpack_item( Character *, item *, const tripoint & ); -std::optional vibe( Character *, item *, const tripoint & ); -std::optional voltmeter( Character *p, item *it, const tripoint & ); -std::optional vortex( Character *, item *, const tripoint & ); -std::optional wash_all_items( Character *, item *, const tripoint & ); -std::optional wash_hard_items( Character *, item *, const tripoint & ); +std::optional acidbomb_act( Character *, item *, const tripoint_bub_ms & ); +std::optional adrenaline_injector( Character *, item *, const tripoint_bub_ms & ); +std::optional afs_translocator( Character *, item *, const tripoint_bub_ms & ); +std::optional bell( Character *, item *, const tripoint_bub_ms & ); +std::optional blood_draw( Character *, item *, const tripoint_bub_ms & ); +std::optional boltcutters( Character *, item *, const tripoint_bub_ms & ); +std::optional break_stick( Character *, item *, const tripoint_bub_ms & ); +std::optional c4( Character *, item *, const tripoint_bub_ms & ); +std::optional call_of_tindalos( Character *, item *, const tripoint_bub_ms & ); +std::optional camera( Character *, item *, const tripoint_bub_ms & ); +std::optional can_goo( Character *, item *, const tripoint_bub_ms & ); +std::optional capture_monster_act( Character *, item *, const tripoint_bub_ms & ); +std::optional heat_solid_items( Character *p, item *it, const tripoint_bub_ms & ); +std::optional heat_liquid_items( Character *p, item *it, const tripoint_bub_ms & ); +std::optional heat_all_items( Character *p, item *it, const tripoint_bub_ms & ); +std::optional capture_monster_veh( Character *, item *, const tripoint_bub_ms & ); +std::optional change_eyes( Character *, item *, const tripoint_bub_ms & ); +std::optional change_skin( Character *, item *, const tripoint_bub_ms & ); +std::optional chop_logs( Character *, item *, const tripoint_bub_ms & ); +std::optional chop_tree( Character *, item *, const tripoint_bub_ms & ); +std::optional clear_rubble( Character *, item *, const tripoint_bub_ms & ); +std::optional coin_flip( Character *, item *, const tripoint_bub_ms & ); +std::optional contacts( Character *, item *, const tripoint_bub_ms & ); +std::optional crowbar( Character *, item *, const tripoint_bub_ms & ); +std::optional crowbar_weak( Character *, item *, const tripoint_bub_ms & ); +std::optional dig( Character *, item *, const tripoint_bub_ms & ); +std::optional dig_channel( Character *, item *, const tripoint_bub_ms & ); +std::optional directional_antenna( Character *, item *, const tripoint_bub_ms & ); +std::optional directional_hologram( Character *, item *, const tripoint_bub_ms & ); +std::optional dive_tank_activate( Character *, item *, const tripoint_bub_ms & ); +std::optional dive_tank( Character *, item *, const tripoint_bub_ms & ); +std::optional dog_whistle( Character *, item *, const tripoint_bub_ms & ); +std::optional ehandcuffs( Character *, item *, const tripoint_bub_ms & ); +std::optional ehandcuffs_tick( Character *, item *, const tripoint_bub_ms & ); +std::optional epic_music( Character *, item *, const tripoint_bub_ms & ); +std::optional einktabletpc( Character *, item *, const tripoint_bub_ms & ); +std::optional emf_passive_on( Character *, item *, const tripoint_bub_ms & ); +std::optional extinguisher( Character *, item *, const tripoint_bub_ms & ); +std::optional fill_pit( Character *, item *, const tripoint_bub_ms & ); +std::optional firecracker( Character *, item *, const tripoint_bub_ms & ); +std::optional firecracker_pack( Character *, item *, const tripoint_bub_ms & ); +std::optional firecracker_pack_act( Character *, item *, const tripoint_bub_ms & ); +std::optional fish_trap( Character *, item *, const tripoint_bub_ms & ); +std::optional fish_trap_tick( Character *, item *, const tripoint_bub_ms & ); +std::optional fishing_rod( Character *, item *, const tripoint_bub_ms & ); +std::optional fitness_check( Character *p, item *it, const tripoint_bub_ms & ); +std::optional foodperson( Character *, item *, const tripoint_bub_ms & ); +std::optional foodperson_voice( Character *, item *, const tripoint_bub_ms & ); +std::optional gasmask( Character *, item *, const tripoint_bub_ms & ); +std::optional gasmask_activate( Character *, item *, const tripoint_bub_ms & ); +std::optional geiger( Character *, item *, const tripoint_bub_ms & ); +std::optional geiger_active( Character *, item *, const tripoint_bub_ms & ); +std::optional granade_act( Character *, item *, const tripoint_bub_ms & ); +std::optional grenade_inc_act( Character *, item *, const tripoint_bub_ms & ); +std::optional gun_repair( Character *, item *, const tripoint_bub_ms & ); +std::optional gunmod_attach( Character *, item *, const tripoint_bub_ms & ); +std::optional hacksaw( Character *, item *, const tripoint_bub_ms &it_pnt ); +std::optional hairkit( Character *, item *, const tripoint_bub_ms & ); +std::optional hand_crank( Character *, item *, const tripoint_bub_ms & ); +std::optional heat_food( Character *, item *, const tripoint_bub_ms & ); +std::optional heatpack( Character *, item *, const tripoint_bub_ms & ); +std::optional hotplate( Character *, item *, const tripoint_bub_ms & ); +std::optional hotplate_atomic( Character *, item *, const tripoint_bub_ms & ); +std::optional jackhammer( Character *, item *, const tripoint_bub_ms & ); +std::optional jet_injector( Character *, item *, const tripoint_bub_ms & ); +std::optional lumber( Character *, item *, const tripoint_bub_ms & ); +std::optional ma_manual( Character *, item *, const tripoint_bub_ms & ); +std::optional magic_8_ball( Character *, item *, const tripoint_bub_ms & ); +std::optional measure_resonance( Character *, item *, const tripoint_bub_ms & ); +std::optional change_outfit( Character *, item *, const tripoint_bub_ms & ); +std::optional electricstorage( Character *, item *, const tripoint_bub_ms & ); +std::optional ebooksave( Character *, item *, const tripoint_bub_ms & ); +std::optional ebookread( Character *, item *, const tripoint_bub_ms & ); +std::optional makemound( Character *, item *, const tripoint_bub_ms & ); +std::optional mace( Character *, item *, const tripoint_bub_ms & ); +std::optional manage_exosuit( Character *, item *, const tripoint_bub_ms & ); +std::optional melatonin_tablet( Character *, item *, const tripoint_bub_ms & ); +std::optional mininuke( Character *, item *, const tripoint_bub_ms & ); +std::optional molotov_lit( Character *, item *, const tripoint_bub_ms & ); +std::optional mop( Character *, item *, const tripoint_bub_ms & ); +std::optional mp3( Character *, item *, const tripoint_bub_ms & ); +std::optional mp3_on( Character *, item *, const tripoint_bub_ms & ); +std::optional mp3_deactivate( Character *, item *, const tripoint_bub_ms & ); +std::optional noise_emitter_on( Character *, item *, const tripoint_bub_ms & ); +std::optional oxygen_bottle( Character *, item *, const tripoint_bub_ms & ); +std::optional oxytorch( Character *, item *, const tripoint_bub_ms & ); +std::optional binder_add_recipe( Character *, item *, const tripoint_bub_ms & ); +std::optional binder_manage_recipe( Character *, item *, const tripoint_bub_ms & ); +std::optional pack_cbm( Character *p, item *it, const tripoint_bub_ms & ); +std::optional pack_item( Character *, item *, const tripoint_bub_ms & ); +std::optional pick_lock( Character *p, item *it, const tripoint_bub_ms &pos ); +std::optional pickaxe( Character *, item *, const tripoint_bub_ms & ); +std::optional play_game( Character *, item *, const tripoint_bub_ms & ); +std::optional portable_game( Character *, item *, const tripoint_bub_ms & ); +std::optional portal( Character *, item *, const tripoint_bub_ms & ); +std::optional radglove( Character *, item *, const tripoint_bub_ms & ); +std::optional radio_mod( Character *, item *, const tripoint_bub_ms & ); +std::optional radio_off( Character *, item *, const tripoint_bub_ms & ); +std::optional radio_on( Character *, item *, const tripoint_bub_ms & ); +std::optional radio_tick( Character *, item *, const tripoint_bub_ms & ); +std::optional remove_all_mods( Character *, item *, const tripoint_bub_ms & ); +std::optional robotcontrol( Character *, item *, const tripoint_bub_ms & ); +std::optional rpgdie( Character *, item *, const tripoint_bub_ms & ); +std::optional seed( Character *, item *, const tripoint_bub_ms & ); +std::optional shavekit( Character *, item *, const tripoint_bub_ms & ); +std::optional shocktonfa_off( Character *, item *, const tripoint_bub_ms & ); +std::optional shocktonfa_on( Character *, item *, const tripoint_bub_ms & ); +std::optional siphon( Character *, item *, const tripoint_bub_ms & ); +std::optional solarpack( Character *, item *, const tripoint_bub_ms & ); +std::optional solarpack_off( Character *, item *, const tripoint_bub_ms & ); +std::optional spray_can( Character *, item *, const tripoint_bub_ms & ); +std::optional stimpack( Character *, item *, const tripoint_bub_ms & ); +std::optional strong_antibiotic( Character *, item *, const tripoint_bub_ms & ); +std::optional talking_doll( Character *, item *, const tripoint_bub_ms & ); +std::optional tazer( Character *, item *, const tripoint_bub_ms & ); +std::optional tazer2( Character *, item *, const tripoint_bub_ms & ); +std::optional teleport( Character *, item *, const tripoint_bub_ms & ); +std::optional toolmod_attach( Character *, item *, const tripoint_bub_ms & ); +std::optional towel( Character *, item *, const tripoint_bub_ms & ); +std::optional unfold_generic( Character *, item *, const tripoint_bub_ms & ); +std::optional unpack_item( Character *, item *, const tripoint_bub_ms & ); +std::optional vibe( Character *, item *, const tripoint_bub_ms & ); +std::optional voltmeter( Character *p, item *it, const tripoint_bub_ms & ); +std::optional vortex( Character *, item *, const tripoint_bub_ms & ); +std::optional wash_all_items( Character *, item *, const tripoint_bub_ms & ); +std::optional wash_hard_items( Character *, item *, const tripoint_bub_ms & ); std::optional wash_items( Character *p, bool soft_items, bool hard_items ); -std::optional wash_soft_items( Character *, item *, const tripoint & ); -std::optional water_purifier( Character *, item *, const tripoint & ); -std::optional water_tablets( Character *, item *, const tripoint & ); -std::optional weak_antibiotic( Character *, item *, const tripoint & ); -std::optional weather_tool( Character *, item *, const tripoint & ); -std::optional sextant( Character *, item *, const tripoint & ); -std::optional lux_meter( Character *, item *, const tripoint & ); -std::optional dbg_lux_meter( Character *, item *, const tripoint & ); -std::optional calories_intake_tracker( Character *p, item *, const tripoint & ); +std::optional wash_soft_items( Character *, item *, const tripoint_bub_ms & ); +std::optional water_purifier( Character *, item *, const tripoint_bub_ms & ); +std::optional water_tablets( Character *, item *, const tripoint_bub_ms & ); +std::optional weak_antibiotic( Character *, item *, const tripoint_bub_ms & ); +std::optional weather_tool( Character *, item *, const tripoint_bub_ms & ); +std::optional sextant( Character *, item *, const tripoint_bub_ms & ); +std::optional lux_meter( Character *, item *, const tripoint_bub_ms & ); +std::optional dbg_lux_meter( Character *, item *, const tripoint_bub_ms & ); +std::optional calories_intake_tracker( Character *p, item *, const tripoint_bub_ms & ); // MACGUFFINS -std::optional radiocar( Character *, item *, const tripoint & ); -std::optional radiocaron( Character *, item *, const tripoint & ); -std::optional radiocontrol( Character *, item *, const tripoint & ); -std::optional radiocontrol_tick( Character *, item *, const tripoint & ); +std::optional radiocar( Character *, item *, const tripoint_bub_ms & ); +std::optional radiocaron( Character *, item *, const tripoint_bub_ms & ); +std::optional radiocontrol( Character *, item *, const tripoint_bub_ms & ); +std::optional radiocontrol_tick( Character *, item *, const tripoint_bub_ms & ); -std::optional multicooker( Character *, item *, const tripoint & ); -std::optional multicooker_tick( Character *, item *, const tripoint & ); +std::optional multicooker( Character *, item *, const tripoint_bub_ms & ); +std::optional multicooker_tick( Character *, item *, const tripoint_bub_ms & ); -std::optional remoteveh( Character *, item *, const tripoint & ); -std::optional remoteveh_tick( Character *, item *, const tripoint & ); +std::optional remoteveh( Character *, item *, const tripoint_bub_ms & ); +std::optional remoteveh_tick( Character *, item *, const tripoint_bub_ms & ); -std::optional craft( Character *, item *, const tripoint & ); +std::optional craft( Character *, item *, const tripoint_bub_ms & ); -std::optional disassemble( Character *, item *, const tripoint & ); +std::optional disassemble( Character *, item *, const tripoint_bub_ms & ); -std::optional post_up( Character *, item *, const tripoint & ); +std::optional post_up( Character *, item *, const tripoint_bub_ms & ); // Helper functions for other iuse functions void cut_log_into_planks( Character & ); -void play_music( Character *p, const tripoint &source, int volume, int max_morale, +void play_music( Character *p, const tripoint_bub_ms &source, int volume, int max_morale, bool play_sounds = true ); std::optional purify_water( Character *p, item *purifier, item_location &water ); int towel_common( Character *, item *, bool ); @@ -236,7 +236,7 @@ bool robotcontrol_can_target( Character *, const monster & ); // Helper for handling pesky wannabe-artists std::optional handle_ground_graffiti( Character &p, item *it, const std::string &prefix, - const tripoint &where ); + const tripoint_bub_ms &where ); //helper for lit cigs std::optional can_smoke( const Character &you ); @@ -272,7 +272,7 @@ heating_requirements heating_requirements_for_weight( const units::mass &, const units::mass &, const units::volume & ); using use_function_pointer = std::optional ( * )( Character *, item *, - const tripoint & ); + const tripoint_bub_ms & ); class iuse_actor { @@ -291,8 +291,8 @@ class iuse_actor virtual ~iuse_actor() = default; virtual void load( const JsonObject &jo, const std::string &src ) = 0; - virtual std::optional use( Character *, item &, const tripoint & ) const = 0; - virtual ret_val can_use( const Character &, const item &, const tripoint & ) const; + virtual std::optional use( Character *, item &, const tripoint_bub_ms & ) const = 0; + virtual ret_val can_use( const Character &, const item &, const tripoint_bub_ms & ) const; virtual void info( const item &, std::vector & ) const {} /** * Returns a deep copy of this object. Example implementation: @@ -333,10 +333,8 @@ struct use_function { use_function( const std::string &type, use_function_pointer f ); explicit use_function( std::unique_ptr f ) : actor( std::move( f ) ) {} - // TODO: get rid of untyped overload - std::optional call( Character *, item &, const tripoint & ) const; std::optional call( Character *, item &, const tripoint_bub_ms & ) const; - ret_val can_call( const Character &, const item &, const tripoint &pos ) const; + ret_val can_call( const Character &, const item &, const tripoint_bub_ms &pos ) const; iuse_actor *get_actor_ptr() { return actor.get(); diff --git a/src/iuse_actor.cpp b/src/iuse_actor.cpp index e3fb154d99d4b..67b64fa01336c 100644 --- a/src/iuse_actor.cpp +++ b/src/iuse_actor.cpp @@ -232,7 +232,7 @@ void iuse_transform::load( const JsonObject &obj, const std::string & ) obj.read( "menu_text", menu_text ); } -std::optional iuse_transform::use( Character *p, item &it, const tripoint & ) const +std::optional iuse_transform::use( Character *p, item &it, const tripoint_bub_ms & ) const { int scale = 1; auto iter = it.type->ammo_scale.find( type ); @@ -367,7 +367,7 @@ void iuse_transform::do_transform( Character *p, item &it, const std::string &va } ret_val iuse_transform::can_use( const Character &p, const item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { if( need_worn && !p.is_worn( it ) ) { return ret_val::make_failure( _( "You need to wear the %1$s before activating it." ), @@ -510,7 +510,7 @@ void unpack_actor::load( const JsonObject &obj, const std::string & ) assign( obj, "filthy_volume_threshold", filthy_vol_threshold ); } -std::optional unpack_actor::use( Character *p, item &it, const tripoint & ) const +std::optional unpack_actor::use( Character *p, item &it, const tripoint_bub_ms & ) const { std::vector items = item_group::items_from( unpack_group, calendar::turn ); item last_armor; @@ -563,7 +563,7 @@ void message_iuse::load( const JsonObject &obj, const std::string & ) } std::optional message_iuse::use( Character *p, item &it, - const tripoint &pos ) const + const tripoint_bub_ms &pos ) const { if( !p ) { return std::nullopt; @@ -599,7 +599,7 @@ void sound_iuse::load( const JsonObject &obj, const std::string & ) } std::optional sound_iuse::use( Character *, item &, - const tripoint &pos ) const + const tripoint_bub_ms &pos ) const { sounds::sound( pos, sound_volume, sounds::sound_t::alarm, sound_message.translated(), true, sound_id, sound_variant ); @@ -625,11 +625,12 @@ std::unique_ptr explosion_iuse::clone() const // Those points must have a clear line of sight and a clear path to // the center of the explosion. // They must also be passable. -static std::vector points_for_gas_cloud( const tripoint ¢er, int radius ) +static std::vector points_for_gas_cloud( const tripoint_bub_ms ¢er, + int radius ) { map &here = get_map(); - std::vector result; - for( const tripoint &p : closest_points_first( center, radius ) ) { + std::vector result; + for( const tripoint_bub_ms &p : closest_points_first( center, radius ) ) { if( here.impassable( p ) ) { continue; } @@ -670,7 +671,7 @@ void explosion_iuse::load( const JsonObject &obj, const std::string & ) obj.read( "scrambler_blast_radius", scrambler_blast_radius ); } -std::optional explosion_iuse::use( Character *p, item &it, const tripoint &pos ) const +std::optional explosion_iuse::use( Character *p, item &it, const tripoint_bub_ms &pos ) const { if( explosion.power >= 0.0f ) { Character *source = p; @@ -682,31 +683,31 @@ std::optional explosion_iuse::use( Character *p, item &it, const tripoint & source = g->find_npc( thrower ); } } - explosion_handler::explosion( source, pos, explosion ); + explosion_handler::explosion( source, pos.raw(), explosion ); } if( draw_explosion_radius >= 0 ) { explosion_handler::draw_explosion( pos, draw_explosion_radius, draw_explosion_color ); } if( do_flashbang ) { - explosion_handler::flashbang( pos, flashbang_player_immune ); + explosion_handler::flashbang( pos.raw(), flashbang_player_immune ); } map &here = get_map(); if( fields_radius >= 0 && fields_type.id() ) { - std::vector gas_sources = points_for_gas_cloud( pos, fields_radius ); - for( tripoint &gas_source : gas_sources ) { + std::vector gas_sources = points_for_gas_cloud( pos, fields_radius ); + for( tripoint_bub_ms &gas_source : gas_sources ) { const int field_intensity = rng( fields_min_intensity, fields_max_intensity ); here.add_field( gas_source, fields_type, field_intensity, 1_turns ); } } if( scrambler_blast_radius >= 0 ) { - for( const tripoint &dest : here.points_in_radius( pos, scrambler_blast_radius ) ) { - explosion_handler::scrambler_blast( dest ); + for( const tripoint_bub_ms &dest : here.points_in_radius( pos, scrambler_blast_radius ) ) { + explosion_handler::scrambler_blast( dest.raw() ); } } if( emp_blast_radius >= 0 ) { - for( const tripoint &dest : here.points_in_radius( pos, emp_blast_radius ) ) { - explosion_handler::emp_blast( dest ); + for( const tripoint_bub_ms &dest : here.points_in_radius( pos, emp_blast_radius ) ) { + explosion_handler::emp_blast( dest.raw() ); } } return 1; @@ -798,7 +799,7 @@ void consume_drug_iuse::info( const item &, std::vector &dump ) const } } -std::optional consume_drug_iuse::use( Character *p, item &it, const tripoint & ) const +std::optional consume_drug_iuse::use( Character *p, item &it, const tripoint_bub_ms & ) const { auto need_these = tools_needed; @@ -844,7 +845,7 @@ std::optional consume_drug_iuse::use( Character *p, item &it, const tripoin for( const auto &field : fields_produced ) { const field_type_id fid = field_type_id( field.first ); for( int i = 0; i < 3; i++ ) { - point offset( rng( -2, 2 ), rng( -2, 2 ) ); + point_rel_ms offset( rng( -2, 2 ), rng( -2, 2 ) ); here.add_field( p->pos_bub() + offset, fid, field.second ); } } @@ -897,7 +898,7 @@ int delayed_transform_iuse::time_to_do( const item &it ) const } std::optional delayed_transform_iuse::use( Character *p, item &it, - const tripoint &pos ) const + const tripoint_bub_ms &pos ) const { if( time_to_do( it ) > 0 ) { p->add_msg_if_player( m_info, "%s", not_ready_msg ); @@ -931,7 +932,7 @@ void place_monster_iuse::load( const JsonObject &obj, const std::string & ) } } -std::optional place_monster_iuse::use( Character *p, item &it, const tripoint & ) const +std::optional place_monster_iuse::use( Character *p, item &it, const tripoint_bub_ms & ) const { if( it.ammo_remaining() < need_charges ) { p->add_msg_if_player( m_info, _( "This requires %d charges to activate." ), need_charges ); @@ -1025,15 +1026,15 @@ void place_npc_iuse::load( const JsonObject &obj, const std::string & ) obj.read( "place_randomly", place_randomly ); } -std::optional place_npc_iuse::use( Character *p, item &, const tripoint & ) const +std::optional place_npc_iuse::use( Character *p, item &, const tripoint_bub_ms & ) const { map &here = get_map(); - const tripoint_range target_range = place_randomly ? - points_in_radius( p->pos(), radius ) : - points_in_radius( choose_adjacent( _( "Place NPC where?" ) ).value_or( p->pos() ), 0 ); + const tripoint_range target_range = place_randomly ? + points_in_radius( p->pos_bub(), radius ) : + points_in_radius( choose_adjacent_bub( _( "Place NPC where?" ) ).value_or( p->pos_bub() ), 0 ); - const std::optional target_pos = - random_point( target_range, [&here]( const tripoint & t ) { + const std::optional target_pos = + random_point( target_range, [&here]( const tripoint_bub_ms & t ) { return here.passable( t ) && here.has_floor_or_support( t ) && !get_creature_tracker().creature_at( t ); } ); @@ -1192,9 +1193,9 @@ static ret_val check_deploy_square( Character *p, item &it, } std::optional deploy_furn_actor::use( Character *p, item &it, - const tripoint &pos ) const + const tripoint_bub_ms &pos ) const { - ret_val suitable = check_deploy_square( p, it, tripoint_bub_ms( pos ) ); + ret_val suitable = check_deploy_square( p, it, pos ); if( !suitable.success() ) { p->add_msg_if_player( m_info, suitable.str() ); return std::nullopt; @@ -1224,9 +1225,10 @@ void deploy_appliance_actor::load( const JsonObject &obj, const std::string & ) mandatory( obj, false, "base", appliance_base ); } -std::optional deploy_appliance_actor::use( Character *p, item &it, const tripoint &pos ) const +std::optional deploy_appliance_actor::use( Character *p, item &it, + const tripoint_bub_ms &pos ) const { - ret_val suitable = check_deploy_square( p, it, tripoint_bub_ms( pos ) ); + ret_val suitable = check_deploy_square( p, it, pos ); if( !suitable.success() ) { p->add_msg_if_player( m_info, suitable.str() ); return std::nullopt; @@ -1282,7 +1284,7 @@ void reveal_map_actor::reveal_targets( const tripoint_abs_omt ¢er, } } -std::optional reveal_map_actor::use( Character *p, item &it, const tripoint & ) const +std::optional reveal_map_actor::use( Character *p, item &it, const tripoint_bub_ms & ) const { if( it.already_used_by_player( *p ) ) { p->add_msg_if_player( _( "There isn't anything new on the %s." ), it.tname() ); @@ -1326,9 +1328,8 @@ bool firestarter_actor::prep_firestarter_use( const Character &p, tripoint_bub_m { // checks for fuel are handled by use and the activity, not here if( pos == p.pos_bub() ) { - if( const std::optional pnt_ = choose_adjacent( _( "Light where?" ) ) ) { - // TODO: fix point types - pos = tripoint_bub_ms( *pnt_ ); + if( const std::optional pnt_ = choose_adjacent_bub( _( "Light where?" ) ) ) { + pos = *pnt_; } else { return false; } @@ -1363,7 +1364,6 @@ bool firestarter_actor::prep_firestarter_use( const Character &p, tripoint_bub_m // Check for an adjacent fire container for( const tripoint_bub_ms &query : here.points_in_radius( pos, 1 ) ) { // Don't ask if we're setting a fire on top of a fireplace - // TODO: fix point types if( here.has_flag_furn( "FIRE_CONTAINER", pos ) ) { break; } @@ -1371,7 +1371,6 @@ bool firestarter_actor::prep_firestarter_use( const Character &p, tripoint_bub_m if( query == pos ) { continue; } - // TODO: fix point types if( here.has_flag_furn( "FIRE_CONTAINER", query ) ) { if( !query_yn( _( "Are you sure you want to start fire here? There's a fireplace adjacent." ) ) ) { return false; @@ -1412,7 +1411,7 @@ void firestarter_actor::resolve_firestarter_use( Character *p, const tripoint_bu } ret_val firestarter_actor::can_use( const Character &p, const item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { if( p.is_underwater() ) { return ret_val::make_failure( _( "You can't do that while underwater." ) ); @@ -1422,14 +1421,14 @@ ret_val firestarter_actor::can_use( const Character &p, const item &it, return ret_val::make_failure( _( "This tool doesn't have enough charges." ) ); } - if( need_sunlight && light_mod( p.pos() ) <= 0.0f ) { + if( need_sunlight && light_mod( p.pos_bub() ) <= 0.0f ) { return ret_val::make_failure( _( "You need direct sunlight to light a fire with this." ) ); } return ret_val::make_success(); } -float firestarter_actor::light_mod( const tripoint &pos ) const +float firestarter_actor::light_mod( const tripoint_bub_ms &pos ) const { if( !need_sunlight ) { return 1.0f; @@ -1439,7 +1438,7 @@ float firestarter_actor::light_mod( const tripoint &pos ) const } if( incident_sun_irradiance( get_weather().weather_id, calendar::turn ) > irradiance::moderate ) { - return std::pow( g->natural_light_level( pos.z ) / 80.0f, 8 ); + return std::pow( g->natural_light_level( pos.z() ) / 80.0f, 8 ); } return 0.0f; @@ -1460,7 +1459,7 @@ int firestarter_actor::moves_cost_by_fuel( const tripoint_bub_ms &pos ) const } std::optional firestarter_actor::use( Character *p, item &it, - const tripoint &spos ) const + const tripoint_bub_ms &spos ) const { if( !p ) { debugmsg( "%s called action firestarter that requires character but no character is present", @@ -1468,9 +1467,8 @@ std::optional firestarter_actor::use( Character *p, item &it, return std::nullopt; } - // TODO: fix point types tripoint_bub_ms pos( spos ); - float light = light_mod( p->pos() ); + float light = light_mod( p->pos_bub() ); if( !prep_firestarter_use( *p, pos ) ) { return std::nullopt; } @@ -1521,7 +1519,7 @@ std::unique_ptr salvage_actor::clone() const return std::make_unique( *this ); } -std::optional salvage_actor::use( Character *p, item &cutter, const tripoint & ) const +std::optional salvage_actor::use( Character *p, item &cutter, const tripoint_bub_ms & ) const { if( !p ) { debugmsg( "%s called action salvage that requires character but no character is present", @@ -1945,7 +1943,7 @@ bool inscribe_actor::item_inscription( item &tool, item &cut ) const return true; } -std::optional inscribe_actor::use( Character *p, item &it, const tripoint & ) const +std::optional inscribe_actor::use( Character *p, item &it, const tripoint_bub_ms & ) const { if( !p ) { debugmsg( "%s called action inscribe that requires character but no character is present", @@ -1972,7 +1970,7 @@ std::optional inscribe_actor::use( Character *p, item &it, const tripoint & } if( choice == 0 ) { - const std::optional dest_ = choose_adjacent( _( "Write where?" ) ); + const std::optional dest_ = choose_adjacent_bub( _( "Write where?" ) ); if( !dest_ ) { return std::nullopt; } @@ -2015,7 +2013,7 @@ std::unique_ptr fireweapon_off_actor::clone() const } std::optional fireweapon_off_actor::use( Character *p, item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { if( !p ) { debugmsg( "%s called action fireweapon_off that requires character but no character is present", @@ -2042,7 +2040,7 @@ std::optional fireweapon_off_actor::use( Character *p, item &it, } ret_val fireweapon_off_actor::can_use( const Character &p, const item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { if( !it.ammo_sufficient( &p ) ) { return ret_val::make_failure( _( "This tool doesn't have enough charges." ) ); @@ -2069,7 +2067,7 @@ std::unique_ptr fireweapon_on_actor::clone() const } std::optional fireweapon_on_actor::use( Character *p, item &it, - const tripoint &pos ) const + const tripoint_bub_ms &pos ) const { bool extinguish = true; translation deactivation_msg; @@ -2118,7 +2116,7 @@ std::unique_ptr manualnoise_actor::clone() const return std::make_unique( *this ); } -std::optional manualnoise_actor::use( Character *p, item &, const tripoint & ) const +std::optional manualnoise_actor::use( Character *p, item &, const tripoint_bub_ms & ) const { // Uses the moves specified by iuse_actor's definition p->mod_moves( -moves ); @@ -2131,7 +2129,7 @@ std::optional manualnoise_actor::use( Character *p, item &, const tripoint } ret_val manualnoise_actor::can_use( const Character &p, const item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { if( !it.ammo_sufficient( &p ) ) { return ret_val::make_failure( _( "This tool doesn't have enough charges." ) ); @@ -2149,7 +2147,8 @@ std::unique_ptr play_instrument_iuse::clone() const return std::make_unique( *this ); } -std::optional play_instrument_iuse::use( Character *p, item &it, const tripoint & ) const +std::optional play_instrument_iuse::use( Character *p, item &it, + const tripoint_bub_ms & ) const { if( it.active ) { it.active = false; @@ -2169,7 +2168,7 @@ std::optional play_instrument_iuse::use( Character *p, item &it, const trip } ret_val play_instrument_iuse::can_use( const Character &p, const item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { // TODO (maybe): Mouth encumbrance? Smoke? Lack of arms? Hand encumbrance? if( p.is_underwater() ) { @@ -2212,7 +2211,7 @@ void musical_instrument_actor::load( const JsonObject &obj, const std::string & } std::optional musical_instrument_actor::use( Character *p, item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { if( !p ) { it.active = false; @@ -2321,13 +2320,13 @@ std::optional musical_instrument_actor::use( Character *p, item &it, } // We already played the sounds, just handle applying effects now - iuse::play_music( p, p->pos(), volume, morale_effect, /*play_sounds=*/false ); + iuse::play_music( p, p->pos_bub(), volume, morale_effect, /*play_sounds=*/false ); return 0; } ret_val musical_instrument_actor::can_use( const Character &p, const item &, - const tripoint & ) const + const tripoint_bub_ms & ) const { // TODO: (maybe): Mouth encumbrance? Smoke? Lack of arms? Hand encumbrance? if( p.is_underwater() ) { @@ -2389,7 +2388,7 @@ void learn_spell_actor::info( const item &, std::vector &dump ) const } } -std::optional learn_spell_actor::use( Character *p, item &, const tripoint & ) const +std::optional learn_spell_actor::use( Character *p, item &, const tripoint_bub_ms & ) const { //TODO: combine/replace the checks below with "checks for conditions" from Character::check_read_condition @@ -2524,7 +2523,7 @@ std::string cast_spell_actor::get_name() const return mundane ? _( "Activate" ) : _( "Cast spell" ); } -std::optional cast_spell_actor::use( Character *p, item &it, const tripoint &pos ) const +std::optional cast_spell_actor::use( Character *p, item &it, const tripoint_bub_ms &pos ) const { if( need_worn && !p->is_worn( it ) ) { p->add_msg_if_player( m_info, _( "You need to wear the %1$s before activating it." ), it.tname() ); @@ -2619,13 +2618,12 @@ static item_location form_loc_recursive( T &loc, item &it ) return item_location( loc, &it ); } -static item_location form_loc( Character &you, const tripoint &p, item &it ) +static item_location form_loc( Character &you, const tripoint_bub_ms &p, item &it ) { if( you.has_item( it ) ) { return form_loc_recursive( you, it ); } - const tripoint_bub_ms bub = tripoint_bub_ms( p ); - map_cursor mc( bub ); + map_cursor mc( p ); if( mc.has_item( it ) ) { return form_loc_recursive( mc, it ); } @@ -2643,7 +2641,7 @@ static item_location form_loc( Character &you, const tripoint &p, item &it ) return item_location( you, &it ); } -std::optional holster_actor::use( Character *you, item &it, const tripoint &p ) const +std::optional holster_actor::use( Character *you, item &it, const tripoint_bub_ms &p ) const { if( you->is_wielding( it ) ) { you->add_msg_if_player( _( "You need to unwield your %s before using it." ), it.tname() ); @@ -2738,7 +2736,7 @@ void ammobelt_actor::info( const item &, std::vector &dump ) const item::nname( belt ) ) ); } -std::optional ammobelt_actor::use( Character *p, item &, const tripoint & ) const +std::optional ammobelt_actor::use( Character *p, item &, const tripoint_bub_ms & ) const { item mag( belt ); mag.ammo_unset(); @@ -2812,7 +2810,7 @@ bool repair_item_actor::can_use_tool( const Character &p, const item &tool, bool return true; } -static item_location get_item_location( Character &p, item &it, const tripoint &pos ) +static item_location get_item_location( Character &p, item &it, const tripoint_bub_ms &pos ) { // Item on a character if( p.has_item( it ) ) { @@ -2836,11 +2834,11 @@ static item_location get_item_location( Character &p, item &it, const tripoint & } // Item on the map - return item_location( map_cursor( tripoint_bub_ms( pos ) ), &it ); + return item_location( map_cursor( pos ), &it ); } std::optional repair_item_actor::use( Character *p, item &it, - const tripoint &position ) const + const tripoint_bub_ms &position ) const { if( !can_use_tool( *p, it, true ) ) { return std::nullopt; @@ -3400,23 +3398,24 @@ void heal_actor::load( const JsonObject &obj, const std::string & ) } } -static Character &get_patient( Character &healer, const tripoint &pos ) +static Character &get_patient( Character &healer, const tripoint_bub_ms &pos ) { - if( healer.pos() == pos ) { + if( healer.pos_bub() == pos ) { return healer; } Character *const person = get_creature_tracker().creature_at( pos ); if( !person ) { // Default to heal self on failure not to break old functionality - add_msg_debug( debugmode::DF_IUSE, "No heal target at position %d,%d,%d", pos.x, pos.y, pos.z ); + add_msg_debug( debugmode::DF_IUSE, "No heal target at position %d,%d,%d", pos.x(), pos.y(), + pos.z() ); return healer; } return *person; } -std::optional heal_actor::use( Character *p, item &it, const tripoint &pos ) const +std::optional heal_actor::use( Character *p, item &it, const tripoint_bub_ms &pos ) const { if( p->cant_do_underwater() ) { return std::nullopt; @@ -3890,18 +3889,18 @@ std::unique_ptr place_trap_actor::clone() const return std::make_unique( *this ); } -static bool is_solid_neighbor( const tripoint &pos, const point &offset ) +static bool is_solid_neighbor( const tripoint_bub_ms &pos, const point_rel_ms &offset ) { map &here = get_map(); - const tripoint_bub_ms a = tripoint_bub_ms( pos ) + tripoint( offset, 0 ); - const tripoint_bub_ms b = tripoint_bub_ms( pos ) - tripoint( offset, 0 ); + const tripoint_bub_ms a = pos + offset; + const tripoint_bub_ms b = pos - offset; return here.move_cost( a ) != 2 && here.move_cost( b ) != 2; } -static bool has_neighbor( const tripoint &pos, const ter_id &terrain_id ) +static bool has_neighbor( const tripoint_bub_ms &pos, const ter_id &terrain_id ) { map &here = get_map(); - for( const tripoint &t : here.points_in_radius( pos, 1, 0 ) ) { + for( const tripoint_bub_ms &t : here.points_in_radius( pos, 1, 0 ) ) { if( here.ter( t ) == terrain_id ) { return true; } @@ -3909,10 +3908,10 @@ static bool has_neighbor( const tripoint &pos, const ter_id &terrain_id ) return false; } -bool place_trap_actor::is_allowed( Character &p, const tripoint &pos, +bool place_trap_actor::is_allowed( Character &p, const tripoint_bub_ms &pos, const std::string &name ) const { - if( !allow_under_player && pos == p.pos() ) { + if( !allow_under_player && pos == p.pos_bub() ) { p.add_msg_if_player( m_info, _( "Yeah. Place the %s at your feet. Real damn smart move." ), name ); return false; @@ -3923,8 +3922,10 @@ bool place_trap_actor::is_allowed( Character &p, const tripoint &pos, return false; } if( needs_solid_neighbor ) { - if( !is_solid_neighbor( pos, point::east ) && !is_solid_neighbor( pos, point::south ) && - !is_solid_neighbor( pos, point::south_east ) && !is_solid_neighbor( pos, point::north_east ) ) { + if( !is_solid_neighbor( pos, point_rel_ms::east ) && + !is_solid_neighbor( pos, point_rel_ms::south ) && + !is_solid_neighbor( pos, point_rel_ms::south_east ) && + !is_solid_neighbor( pos, point_rel_ms::north_east ) ) { p.add_msg_if_player( m_info, _( "You must place the %s between two solid tiles." ), name ); return false; } @@ -3944,24 +3945,25 @@ bool place_trap_actor::is_allowed( Character &p, const tripoint &pos, name ); } else { p.add_msg_if_player( m_bad, _( "You trigger a %s!" ), existing_trap.name() ); - existing_trap.trigger( pos, p ); + existing_trap.trigger( pos.raw(), p ); } return false; } return true; } -static void place_and_add_as_known( Character &p, const tripoint &pos, const trap_str_id &id ) +static void place_and_add_as_known( Character &p, const tripoint_bub_ms &pos, + const trap_str_id &id ) { map &here = get_map(); here.trap_set( pos, id ); const trap &tr = here.tr_at( pos ); if( !tr.can_see( pos, p ) ) { - p.add_known_trap( pos, tr ); + p.add_known_trap( pos.raw(), tr ); } } -std::optional place_trap_actor::use( Character *p, item &it, const tripoint & ) const +std::optional place_trap_actor::use( Character *p, item &it, const tripoint_bub_ms & ) const { const bool could_bury = !bury_question.empty(); if( !allow_underwater && p->cant_do_underwater() ) { @@ -3970,12 +3972,13 @@ std::optional place_trap_actor::use( Character *p, item &it, const tripoint if( p->cant_do_mounted() ) { return std::nullopt; } - const std::optional pos_ = choose_adjacent( string_format( _( "Place %s where?" ), - it.tname() ) ); + const std::optional pos_ = choose_adjacent_bub( string_format( + _( "Place %s where?" ), + it.tname() ) ); if( !pos_ ) { return std::nullopt; } - tripoint pos = *pos_; + tripoint_bub_ms pos = *pos_; if( !is_allowed( *p, pos, it.tname() ) ) { return std::nullopt; @@ -3986,9 +3989,10 @@ std::optional place_trap_actor::use( Character *p, item &it, const tripoint outer_layer_trap.obj().get_trap_radius() + 1; if( unburied_data.trap.obj().get_trap_radius() > 0 ) { // Math correction for multi-tile traps - pos.x = ( pos.x - p->posx() ) * distance_to_trap_center + p->posx(); - pos.y = ( pos.y - p->posy() ) * distance_to_trap_center + p->posy(); - for( const tripoint &t : here.points_in_radius( pos, outer_layer_trap.obj().get_trap_radius(), + pos.x() = ( pos.x() - p->posx() ) * distance_to_trap_center + p->posx(); + pos.y() = ( pos.y() - p->posy() ) * distance_to_trap_center + p->posy(); + for( const tripoint_bub_ms &t : here.points_in_radius( pos, + outer_layer_trap.obj().get_trap_radius(), 0 ) ) { if( !is_allowed( *p, t, it.tname() ) ) { p->add_msg_if_player( m_info, @@ -4033,7 +4037,8 @@ std::optional place_trap_actor::use( Character *p, item &it, const tripoint if( !placed_trap.is_null() ) { const_cast( placed_trap ).set_trap_data( it.typeId() ); } - for( const tripoint &t : here.points_in_radius( pos, data.trap.obj().get_trap_radius(), 0 ) ) { + for( const tripoint_bub_ms &t : here.points_in_radius( pos, data.trap.obj().get_trap_radius(), + 0 ) ) { if( t != pos ) { place_and_add_as_known( *p, t, outer_layer_trap ); } @@ -4047,7 +4052,7 @@ void emit_actor::load( const JsonObject &obj, const std::string & ) assign( obj, "scale_qty", scale_qty ); } -std::optional emit_actor::use( Character *, item &it, const tripoint &pos ) const +std::optional emit_actor::use( Character *, item &it, const tripoint_bub_ms &pos ) const { map &here = get_map(); const float scaling = scale_qty ? it.charges : 1.0f; @@ -4087,7 +4092,7 @@ void saw_barrel_actor::load( const JsonObject &jo, const std::string & ) } //Todo: Make this consume charges if performed with a tool that uses charges. -std::optional saw_barrel_actor::use( Character *p, item &it, const tripoint & ) const +std::optional saw_barrel_actor::use( Character *p, item &it, const tripoint_bub_ms & ) const { if( !p ) { debugmsg( "%s called action saw_barrel that requires character but no character is present", @@ -4148,7 +4153,7 @@ void saw_stock_actor::load( const JsonObject &jo, const std::string & ) } //Todo: Make this consume charges if performed with a tool that uses charges. -std::optional saw_stock_actor::use( Character *p, item &it, const tripoint & ) const +std::optional saw_stock_actor::use( Character *p, item &it, const tripoint_bub_ms & ) const { if( !p ) { debugmsg( "%s called action saw_stock that requires character but no character is present", @@ -4224,7 +4229,7 @@ void molle_attach_actor::load( const JsonObject &jo, const std::string & ) } std::optional molle_attach_actor::use( Character *p, item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { if( !p ) { debugmsg( "%s called action molle_attach that requires character but no character is present", @@ -4256,7 +4261,7 @@ std::unique_ptr molle_attach_actor::clone() const } std::optional molle_detach_actor::use( Character *p, item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { std::vector items_attached = it.get_contents().get_added_pockets(); @@ -4290,7 +4295,7 @@ void molle_detach_actor::load( const JsonObject &jo, const std::string & ) } std::optional install_bionic_actor::use( Character *p, item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { if( p->can_install_bionics( *it.type, *p, false ) ) { if( !p->has_trait( trait_DEBUG_BIONICS ) && !p->has_flag( json_flag_MANUAL_CBM_INSTALLATION ) ) { @@ -4305,7 +4310,7 @@ std::optional install_bionic_actor::use( Character *p, item &it, } ret_val install_bionic_actor::can_use( const Character &p, const item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { if( !it.is_bionic() ) { return ret_val::make_failure(); @@ -4362,7 +4367,7 @@ void install_bionic_actor::finalize( const itype_id &my_item_type ) } std::optional detach_gunmods_actor::use( Character *p, item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { auto filter_irremovable = []( std::vector &gunmods ) { gunmods.erase( @@ -4415,7 +4420,7 @@ std::optional detach_gunmods_actor::use( Character *p, item &it, } ret_val detach_gunmods_actor::can_use( const Character &p, const item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { const std::vector mods = it.gunmods(); @@ -4454,7 +4459,7 @@ void detach_gunmods_actor::finalize( const itype_id &my_item_type ) } std::optional modify_gunmods_actor::use( Character *p, item &it, - const tripoint &pnt ) const + const tripoint_bub_ms &pnt ) const { std::vector mods; @@ -4487,7 +4492,7 @@ std::optional modify_gunmods_actor::use( Character *p, item &it, } ret_val modify_gunmods_actor::can_use( const Character &p, const item &it, - const tripoint & ) const + const tripoint_bub_ms & ) const { if( !p.is_wielding( it ) ) { return ret_val::make_failure( _( "Need to be wielding." ) ); @@ -4612,7 +4617,7 @@ void link_up_actor::info( const item &it, std::vector &dump ) const } } -std::optional link_up_actor::use( Character *p, item &it, const tripoint &pnt ) const +std::optional link_up_actor::use( Character *p, item &it, const tripoint_bub_ms &pnt ) const { if( !p ) { debugmsg( "%s called action link_up that requires character but no character is present", @@ -4935,17 +4940,18 @@ std::optional link_up_actor::link_to_veh_app( Character *p, item &it, map &here = get_map(); // Selection: Attach electrical cable to vehicle ports / appliances, OR vehicle batteries. - const auto can_link = [&here, &to_ports]( const tripoint & point ) { + const auto can_link = [&here, &to_ports]( const tripoint_bub_ms & point ) { const optional_vpart_position ovp = here.veh_at( point ); return ovp && ovp->vehicle().avail_linkable_part( ovp->mount_pos(), to_ports ) != -1; }; - const std::optional pnt_ = choose_adjacent_highlight( _( "Attach the cable where?" ), - "", can_link, false, false ); + const std::optional pnt_ = choose_adjacent_highlight( + _( "Attach the cable where?" ), + "", can_link, false, false ); if( !pnt_ ) { p->add_msg_if_player( _( "Never mind." ) ); return std::nullopt; } - const tripoint &selection = *pnt_; + const tripoint_bub_ms &selection = *pnt_; const optional_vpart_position sel_vp = here.veh_at( selection ); if( !sel_vp ) { p->add_msg_if_player( _( "There's no vehicle there." ) ); @@ -5001,9 +5007,10 @@ std::optional link_up_actor::link_to_veh_app( Character *p, item &it, const bool using_power_cord = it.typeId() == itype_power_cord; if( using_power_cord && it.link().t_veh->is_powergrid() && sel_vp->vehicle().is_powergrid() ) { // If both vehicles are adjacent power grids, try to merge them together first. - const point prev_pos = here.bub_from_abs( it.link().t_veh->coord_translate( it.link().t_mount ) + - it.link().t_abs_pos ).xy().raw(); - if( selection.xy().distance( prev_pos ) <= 1.5f && + const point_bub_ms prev_pos = here.bub_from_abs( it.link().t_veh->coord_translate( + it.link().t_mount ) + + it.link().t_abs_pos ).xy(); + if( selection.xy().raw().distance( prev_pos.raw() ) <= 1.5f && it.link().t_veh->merge_appliance_into_grid( sel_vp->vehicle() ) ) { it.link().t_veh->part_removal_cleanup(); p->add_msg_if_player( _( "You merge the two power grids." ) ); @@ -5035,19 +5042,19 @@ std::optional link_up_actor::link_tow_cable( Character *p, item &it, { map &here = get_map(); - const auto can_link = [&here]( const tripoint & point ) { + const auto can_link = [&here]( const tripoint_bub_ms & point ) { const optional_vpart_position ovp = here.veh_at( point ); return ovp && ovp->vehicle().is_external_part( point ); }; - const std::optional pnt_ = choose_adjacent_highlight( - to_towing ? _( "Attach cable to the vehicle that will do the towing." ) : - _( "Attach cable to the vehicle that will be towed." ), "", can_link, false, false ); + const std::optional pnt_ = choose_adjacent_highlight( + to_towing ? _( "Attach cable to the vehicle that will do the towing." ) : + _( "Attach cable to the vehicle that will be towed." ), "", can_link, false, false ); if( !pnt_ ) { p->add_msg_if_player( _( "Never mind." ) ); return std::nullopt; } - const tripoint &selection = *pnt_; + const tripoint_bub_ms &selection = *pnt_; const optional_vpart_position sel_vp = here.veh_at( selection ); if( !sel_vp ) { p->add_msg_if_player( _( "There's no vehicle there." ) ); @@ -5095,7 +5102,7 @@ std::optional link_up_actor::link_tow_cable( Character *p, item &it, } std::optional link_up_actor::link_extend_cable( Character *p, item &it, - const tripoint &pnt ) const + const tripoint_bub_ms &pnt ) const { avatar *you = p->as_avatar(); if( !you ) { @@ -5263,7 +5270,7 @@ void deploy_tent_actor::load( const JsonObject &obj, const std::string & ) assign( obj, "broken_type", broken_type ); } -std::optional deploy_tent_actor::use( Character *p, item &it, const tripoint & ) const +std::optional deploy_tent_actor::use( Character *p, item &it, const tripoint_bub_ms & ) const { int diam = 2 * radius + 1; if( p->cant_do_mounted() ) { @@ -5341,7 +5348,7 @@ void weigh_self_actor::info( const item &, std::vector &dump ) const _( "Use this item to weigh yourself. Includes everything you are wearing." ) ); } -std::optional weigh_self_actor::use( Character *p, item &, const tripoint & ) const +std::optional weigh_self_actor::use( Character *p, item &, const tripoint_bub_ms & ) const { if( p->is_mounted() ) { p->add_msg_if_player( m_info, _( "You cannot weigh yourself while mounted." ) ); @@ -5385,7 +5392,7 @@ void sew_advanced_actor::load( const JsonObject &obj, const std::string & ) } } -std::optional sew_advanced_actor::use( Character *p, item &it, const tripoint & ) const +std::optional sew_advanced_actor::use( Character *p, item &it, const tripoint_bub_ms & ) const { if( p->is_npc() ) { return std::nullopt; @@ -5626,7 +5633,7 @@ void change_scent_iuse::load( const JsonObject &obj, const std::string & ) assign( obj, "waterproof", waterproof ); } -std::optional change_scent_iuse::use( Character *p, item &it, const tripoint & ) const +std::optional change_scent_iuse::use( Character *p, item &it, const tripoint_bub_ms & ) const { p->set_value( "prev_scent", p->get_type_of_scent().c_str() ); if( waterproof ) { @@ -5679,7 +5686,7 @@ void effect_on_conditons_actor::info( const item &, std::vector &dump } std::optional effect_on_conditons_actor::use( Character *p, item &it, - const tripoint &point ) const + const tripoint_bub_ms &point ) const { if( need_worn && !p->is_worn( it ) ) { p->add_msg_if_player( m_info, _( "You need to wear the %1$s before activating it." ), it.tname() ); @@ -5699,7 +5706,7 @@ std::optional effect_on_conditons_actor::use( Character *p, item &it, } loc = item_location( *p->as_character(), &it ); } else { - loc = item_location( map_cursor( tripoint_bub_ms( point ) ), &it ); + loc = item_location( map_cursor( point ), &it ); } dialogue d( ( char_ptr == nullptr ? nullptr : get_talker_for( char_ptr ) ), get_talker_for( loc ) ); diff --git a/src/iuse_actor.h b/src/iuse_actor.h index 688037b515fec..b5206bc787056 100644 --- a/src/iuse_actor.h +++ b/src/iuse_actor.h @@ -113,8 +113,8 @@ class iuse_transform : public iuse_actor ~iuse_transform() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; - ret_val can_use( const Character &, const item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; + ret_val can_use( const Character &, const item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; std::string get_name() const override; void finalize( const itype_id &my_item_type ) override; @@ -142,7 +142,7 @@ class unpack_actor : public iuse_actor ~unpack_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *p, item &it, const tripoint & ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector &dump ) const override; }; @@ -160,7 +160,7 @@ class message_iuse : public iuse_actor ~message_iuse() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; std::string get_name() const override; }; @@ -182,7 +182,7 @@ class sound_iuse : public iuse_actor ~sound_iuse() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; std::string get_name() const override; }; @@ -220,7 +220,7 @@ class explosion_iuse : public iuse_actor ~explosion_iuse() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector & ) const override; }; @@ -268,7 +268,7 @@ class consume_drug_iuse : public iuse_actor ~consume_drug_iuse() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector & ) const override; @@ -303,7 +303,7 @@ class delayed_transform_iuse : public iuse_transform ~delayed_transform_iuse() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -336,7 +336,7 @@ class place_monster_iuse : public iuse_actor place_monster_iuse() : iuse_actor( "place_monster" ) { } ~place_monster_iuse() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -364,7 +364,7 @@ class change_scent_iuse : public iuse_actor change_scent_iuse() : iuse_actor( "change_scent" ) { } ~change_scent_iuse() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -383,7 +383,7 @@ class place_npc_iuse : public iuse_actor place_npc_iuse() : iuse_actor( "place_npc" ) { } ~place_npc_iuse() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -402,7 +402,7 @@ class deploy_furn_actor : public iuse_actor ~deploy_furn_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector & ) const override; }; @@ -419,7 +419,7 @@ class deploy_appliance_actor : public iuse_actor ~deploy_appliance_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector & ) const override; }; @@ -455,7 +455,7 @@ class reveal_map_actor : public iuse_actor ~reveal_map_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -484,7 +484,7 @@ class firestarter_actor : public iuse_actor /** Player here isn't const because pyromaniacs gain a mood boost from it */ static void resolve_firestarter_use( Character *p, const tripoint_bub_ms &pos ); /** Modifier on speed - higher is better, 0 means it won't work. */ - float light_mod( const tripoint &pos ) const; + float light_mod( const tripoint_bub_ms &pos ) const; /** Checks quality of fuel on the tile and interpolates move cost based on that. */ int moves_cost_by_fuel( const tripoint_bub_ms &pos ) const; @@ -492,8 +492,8 @@ class firestarter_actor : public iuse_actor ~firestarter_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; - ret_val can_use( const Character &, const item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; + ret_val can_use( const Character &, const item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -514,7 +514,7 @@ class salvage_actor : public iuse_actor ~salvage_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; private: void cut_up( Character &p, item_location &cut ) const; @@ -557,7 +557,7 @@ class inscribe_actor : public iuse_actor ~inscribe_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -580,8 +580,8 @@ class fireweapon_off_actor : public iuse_actor ~fireweapon_off_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; - ret_val can_use( const Character &, const item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; + ret_val can_use( const Character &, const item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -601,7 +601,7 @@ class fireweapon_on_actor : public iuse_actor ~fireweapon_on_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -622,8 +622,8 @@ class manualnoise_actor : public iuse_actor ~manualnoise_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; - ret_val can_use( const Character &, const item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; + ret_val can_use( const Character &, const item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -634,8 +634,8 @@ class play_instrument_iuse : public iuse_actor ~play_instrument_iuse() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; - ret_val can_use( const Character &, const item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; + ret_val can_use( const Character &, const item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -679,8 +679,8 @@ class musical_instrument_actor : public iuse_actor ~musical_instrument_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; - ret_val can_use( const Character &, const item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; + ret_val can_use( const Character &, const item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -697,7 +697,7 @@ class learn_spell_actor : public iuse_actor ~learn_spell_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *p, item &, const tripoint & ) const override; + std::optional use( Character *p, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector & ) const override; }; @@ -724,7 +724,7 @@ class cast_spell_actor : public iuse_actor ~cast_spell_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *p, item &it, const tripoint & ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector & ) const override; std::string get_name() const override; @@ -751,7 +751,7 @@ class holster_actor : public iuse_actor ~holster_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector & ) const override; }; @@ -765,7 +765,7 @@ class ammobelt_actor : public iuse_actor ~ammobelt_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector & ) const override; }; @@ -856,7 +856,7 @@ class repair_item_actor : public iuse_actor ~repair_item_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; std::string get_name() const override; @@ -923,7 +923,7 @@ class heal_actor : public iuse_actor ~heal_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector & ) const override; }; @@ -965,12 +965,12 @@ class place_trap_actor : public iuse_actor * The trap that makes up the outer layer of a multi-tile trap. This is not supported for buried traps! */ trap_str_id outer_layer_trap; - bool is_allowed( Character &p, const tripoint &pos, const std::string &name ) const; + bool is_allowed( Character &p, const tripoint_bub_ms &pos, const std::string &name ) const; explicit place_trap_actor( const std::string &type = "place_trap" ); ~place_trap_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -984,7 +984,7 @@ class emit_actor : public iuse_actor explicit emit_actor( const std::string &type = "emit_actor" ) : iuse_actor( type ) {} ~emit_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void finalize( const itype_id &my_item_type ) override; }; @@ -995,7 +995,7 @@ class saw_barrel_actor : public iuse_actor explicit saw_barrel_actor( const std::string &type = "saw_barrel" ) : iuse_actor( type ) {} void load( const JsonObject &jo, const std::string & ) override; - std::optional use( Character *p, item &it, const tripoint &pnt ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms &pnt ) const override; std::unique_ptr clone() const override; ret_val can_use_on( const Character &you, const item &it, const item &target ) const; @@ -1007,7 +1007,7 @@ class saw_stock_actor : public iuse_actor explicit saw_stock_actor( const std::string &type = "saw_stock" ) : iuse_actor( type ) {} void load( const JsonObject &jo, const std::string & ) override; - std::optional use( Character *p, item &it, const tripoint &pnt ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms &pnt ) const override; std::unique_ptr clone() const override; ret_val can_use_on( const Character &you, const item &it, const item &target ) const; @@ -1023,7 +1023,7 @@ class molle_attach_actor : public iuse_actor int moves; void load( const JsonObject &jo, const std::string & ) override; - std::optional use( Character *p, item &it, const tripoint &pnt ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms &pnt ) const override; std::unique_ptr clone() const override; }; @@ -1036,7 +1036,7 @@ class molle_detach_actor : public iuse_actor int moves; void load( const JsonObject &jo, const std::string & ) override; - std::optional use( Character *p, item &it, const tripoint &pnt ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms &pnt ) const override; std::unique_ptr clone() const override; }; @@ -1046,8 +1046,8 @@ class install_bionic_actor : public iuse_actor explicit install_bionic_actor( const std::string &type = "install_bionic" ) : iuse_actor( type ) {} void load( const JsonObject &, const std::string & ) override {} - std::optional use( Character *p, item &it, const tripoint &pnt ) const override; - ret_val can_use( const Character &, const item &it, const tripoint & ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms &pnt ) const override; + ret_val can_use( const Character &, const item &it, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void finalize( const itype_id &my_item_type ) override; }; @@ -1058,8 +1058,8 @@ class detach_gunmods_actor : public iuse_actor explicit detach_gunmods_actor( const std::string &type = "detach_gunmods" ) : iuse_actor( type ) {} void load( const JsonObject &, const std::string & ) override {} - std::optional use( Character *p, item &it, const tripoint &pnt ) const override; - ret_val can_use( const Character &, const item &it, const tripoint & ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms &pnt ) const override; + ret_val can_use( const Character &, const item &it, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void finalize( const itype_id &my_item_type ) override; }; @@ -1070,8 +1070,8 @@ class modify_gunmods_actor : public iuse_actor explicit modify_gunmods_actor( const std::string &type = "modify_gunmods" ) : iuse_actor( type ) {} void load( const JsonObject &, const std::string & ) override {} - std::optional use( Character *p, item &it, const tripoint &pnt ) const override; - ret_val can_use( const Character &, const item &it, const tripoint & ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms &pnt ) const override; + ret_val can_use( const Character &, const item &it, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void finalize( const itype_id &my_item_type ) override; }; @@ -1095,7 +1095,7 @@ class link_up_actor : public iuse_actor std::optional link_to_veh_app( Character *p, item &it, bool to_ports ) const; std::optional link_tow_cable( Character *p, item &it, bool to_towing ) const; - std::optional link_extend_cable( Character *p, item &it, const tripoint &pnt ) const; + std::optional link_extend_cable( Character *p, item &it, const tripoint_bub_ms &pnt ) const; std::optional remove_extensions( Character *p, item &it ) const; link_up_actor() : iuse_actor( "link_up" ) {} @@ -1105,7 +1105,7 @@ class link_up_actor : public iuse_actor std::unique_ptr clone() const override; std::string get_name() const override; void info( const item &, std::vector & ) const override; - std::optional use( Character *p, item &it, const tripoint &pnt ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms &pnt ) const override; }; class deploy_tent_actor : public iuse_actor @@ -1123,7 +1123,7 @@ class deploy_tent_actor : public iuse_actor ~deploy_tent_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; bool check_intact( const tripoint_bub_ms ¢er ) const; @@ -1142,7 +1142,7 @@ class weigh_self_actor : public iuse_actor ~weigh_self_actor() override = default; void load( const JsonObject &jo, const std::string & ) override; - std::optional use( Character *p, item &, const tripoint & ) const override; + std::optional use( Character *p, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; void info( const item &, std::vector & ) const override; }; @@ -1164,7 +1164,7 @@ class sew_advanced_actor : public iuse_actor ~sew_advanced_actor() override = default; void load( const JsonObject &obj, const std::string & ) override; - std::optional use( Character *, item &, const tripoint & ) const override; + std::optional use( Character *, item &, const tripoint_bub_ms & ) const override; std::unique_ptr clone() const override; }; @@ -1186,7 +1186,7 @@ class effect_on_conditons_actor : public iuse_actor ~effect_on_conditons_actor() override = default; void load( const JsonObject &obj, const std::string &src ) override; - std::optional use( Character *p, item &it, const tripoint &point ) const override; + std::optional use( Character *p, item &it, const tripoint_bub_ms &point ) const override; std::unique_ptr clone() const override; std::string get_name() const override; void info( const item &, std::vector & ) const override; diff --git a/src/npcmove.cpp b/src/npcmove.cpp index 2f0063ad5028e..6f4975bae48cf 100644 --- a/src/npcmove.cpp +++ b/src/npcmove.cpp @@ -2331,8 +2331,8 @@ void outfit::activate_combat_items( npc &guy ) if( transform->target->has_flag( flag_USE_UPS ) && guy.available_ups() == 0_kJ ) { continue; } - if( transform->can_use( guy, candidate, tripoint::zero ).success() ) { - transform->use( &guy, candidate, tripoint::zero ); + if( transform->can_use( guy, candidate, tripoint_bub_ms::zero ).success() ) { + transform->use( &guy, candidate, tripoint_bub_ms::zero ); guy.add_msg_if_npc( _( " activates their %s." ), candidate.display_name() ); } } @@ -2351,8 +2351,8 @@ void outfit::deactivate_combat_items( npc &guy ) candidate.active ) { const iuse_transform *transform = dynamic_cast ( candidate.type->get_use( "transform" )->get_actor_ptr() ); - if( transform->can_use( guy, candidate, tripoint::zero ).success() ) { - transform->use( &guy, candidate, tripoint::zero ); + if( transform->can_use( guy, candidate, tripoint_bub_ms::zero ).success() ) { + transform->use( &guy, candidate, tripoint_bub_ms::zero ); guy.add_msg_if_npc( _( " deactivates their %s." ), candidate.display_name() ); } } diff --git a/src/vehicle_use.cpp b/src/vehicle_use.cpp index d23aecb156148..0a55554a8d95e 100644 --- a/src/vehicle_use.cpp +++ b/src/vehicle_use.cpp @@ -372,7 +372,7 @@ void vehicle::build_electronics_menu( veh_menu &menu ) menu.add( _( "Play arcade machine" ) ) .hotkey( "ARCADE" ) .enable( !!arc_itm ) - .on_submit( [arc_itm] { iuse::portable_game( &get_avatar(), arc_itm, tripoint::zero ); } ); + .on_submit( [arc_itm] { iuse::portable_game( &get_avatar(), arc_itm, tripoint_bub_ms::zero ); } ); break; } } @@ -938,7 +938,7 @@ void vehicle::play_music() const { Character &player_character = get_player_character(); for( const vpart_reference &vp : get_enabled_parts( "STEREO" ) ) { - iuse::play_music( &player_character, vp.pos_bub().raw(), 15, 30 ); + iuse::play_music( &player_character, vp.pos_bub(), 15, 30 ); } } diff --git a/tests/battery_mod_test.cpp b/tests/battery_mod_test.cpp index 1572cbfc3b694..dbdf4d343600e 100644 --- a/tests/battery_mod_test.cpp +++ b/tests/battery_mod_test.cpp @@ -174,7 +174,7 @@ TEST_CASE( "battery_tool_mod_test", "[battery][mod]" ) Character *dummy = &get_avatar(); clear_avatar(); - actor->use( dummy, flashlight, dummy->pos() ); + actor->use( dummy, flashlight, dummy->pos_bub() ); // Regression tests for #42764 / #42854 THEN( "mod remains installed" ) { diff --git a/tests/iuse_actor_test.cpp b/tests/iuse_actor_test.cpp index b1945f2286fe6..f0c0f0f924faf 100644 --- a/tests/iuse_actor_test.cpp +++ b/tests/iuse_actor_test.cpp @@ -108,7 +108,7 @@ TEST_CASE( "tool_transform_when_activated", "[iuse][tool][transform]" ) const use_function *use = flashlight.type->get_use( "transform" ); REQUIRE( use != nullptr ); const iuse_transform *actor = dynamic_cast( use->get_actor_ptr() ); - actor->use( dummy, flashlight, dummy->pos() ); + actor->use( dummy, flashlight, dummy->pos_bub() ); THEN( "it becomes active" ) { CHECK( flashlight.active ); diff --git a/tests/player_activities_test.cpp b/tests/player_activities_test.cpp index 366ddabae4ae2..ae98243c58445 100644 --- a/tests/player_activities_test.cpp +++ b/tests/player_activities_test.cpp @@ -384,7 +384,7 @@ TEST_CASE( "shearing", "[activity][shearing][animals]" ) const use_function *use = elec_shears.type->get_use( "transform" ); REQUIRE( use != nullptr ); const iuse_transform *actor = dynamic_cast( use->get_actor_ptr() ); - actor->use( &dummy, elec_shears, dummy.pos() ); + actor->use( &dummy, elec_shears, dummy.pos_bub() ); dummy.i_add( elec_shears ); REQUIRE( dummy.max_quality( qual_SHEAR ) == 3 ); @@ -430,7 +430,7 @@ TEST_CASE( "shearing", "[activity][shearing][animals]" ) const use_function *use = elec_shears.type->get_use( "transform" ); REQUIRE( use != nullptr ); const iuse_transform *actor = dynamic_cast( use->get_actor_ptr() ); - actor->use( &dummy, elec_shears, dummy.pos() ); + actor->use( &dummy, elec_shears, dummy.pos_bub() ); dummy.i_add( elec_shears ); REQUIRE( dummy.max_quality( qual_SHEAR ) == 3 );