Skip to content

Commit

Permalink
Merge pull request #75815 from mqrause/reload_autoselection_fix
Browse files Browse the repository at this point in the history
Fix reloading with speedloader when it's the only choice
  • Loading branch information
dseguin authored Aug 20, 2024
2 parents 94a2d4d + 25bfa40 commit 078a0c2
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 5 deletions.
2 changes: 1 addition & 1 deletion src/inventory_ui.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2924,7 +2924,7 @@ drop_location inventory_selector::get_only_choice() const
for( const inventory_column *col : columns ) {
const std::vector<inventory_entry *> ent = col->get_entries( return_item, true );
if( !ent.empty() ) {
return { ent.front()->any_item(), static_cast<int>( ent.front()->get_available_count() ) };
return { ent.front()->any_item(), static_cast<int>( ent.front()->chosen_count ) };
}
}

Expand Down
19 changes: 15 additions & 4 deletions tests/reloading_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
#include <set>
#include <vector>

#include "activity_actor_definitions.h"
#include "avatar.h"
#include "calendar.h"
#include "cata_catch.h"
Expand Down Expand Up @@ -798,9 +799,9 @@ TEST_CASE( "reload_gun_with_integral_magazine_using_speedloader", "[reload],[gun
// Make sure the player doesn't drop anything :P
dummy.wear_item( item( "backpack", calendar::turn_zero ) );

item_location ammo = dummy.i_add( item( "38_special", calendar::turn_zero,
item::default_charges_tag{} ) );
item_location speedloader = dummy.i_add( item( "38_speedloader", calendar::turn_zero, false ) );
item_location ammo = dummy.i_add( item( "38_special", calendar::turn_zero,
speedloader->remaining_ammo_capacity() ) );
item_location gun = dummy.i_add( item( "sw_619", calendar::turn_zero, false ) );

REQUIRE( dummy.has_item( *ammo ) );
Expand All @@ -815,9 +816,19 @@ TEST_CASE( "reload_gun_with_integral_magazine_using_speedloader", "[reload],[gun
REQUIRE( speedloader_success );
REQUIRE( speedloader->remaining_ammo_capacity() == 0 );

bool success = gun->reload( dummy, speedloader, speedloader->ammo_remaining() );
// This automatically selects the speedloader as ammo
// as long as dummy has nothing else available.
// If there are multiple options, it will crash from opening a ui.
item::reload_option opt = dummy.select_ammo( gun );

REQUIRE( success );
REQUIRE( opt );

dummy.assign_activity( reload_activity_actor( std::move( opt ) ) );
if( !!dummy.activity ) {
process_activity( dummy );
}

//REQUIRE( success );
REQUIRE( gun->remaining_ammo_capacity() == 0 );
// Speedloader is still in inventory.
REQUIRE( dummy.has_item( *speedloader ) );
Expand Down

0 comments on commit 078a0c2

Please sign in to comment.