Fixed Elixir only being useable if the first move was missing PP (#4594)
* Fixed Elixir only being useable is the first move was missing PP * Update restore_pp.c Commented out the test that doesn't actually test what it's supposed to due to current test system. --------- Co-authored-by: Hedara <hedara90@gmail.com>
This commit is contained in:
parent
a28ee83b06
commit
4ccfd5355d
2 changed files with 29 additions and 2 deletions
|
@ -1254,11 +1254,11 @@ bool32 CannotUseItemsInBattle(u16 itemId, struct Pokemon *mon)
|
|||
cannotUse = TRUE;
|
||||
break;
|
||||
case EFFECT_ITEM_RESTORE_PP:
|
||||
if (ItemId_GetEffect(itemId)[6] == ITEM4_HEAL_PP)
|
||||
if (ItemId_GetEffect(itemId)[4] == ITEM4_HEAL_PP)
|
||||
{
|
||||
for (i = 0; i < MAX_MON_MOVES; i++)
|
||||
{
|
||||
if (GetMonData(mon, MON_DATA_PP1 + i) < CalculatePPWithBonus(GetMonData(mon, MON_DATA_MOVE1 + i), GetMonData(mon, MON_DATA_PP_BONUSES), i));
|
||||
if (GetMonData(mon, MON_DATA_PP1 + i) < CalculatePPWithBonus(GetMonData(mon, MON_DATA_MOVE1 + i), GetMonData(mon, MON_DATA_PP_BONUSES), i))
|
||||
break;
|
||||
}
|
||||
if (i == MAX_MON_MOVES)
|
||||
|
|
|
@ -66,3 +66,30 @@ SINGLE_BATTLE_TEST("Max Elixir restores the PP of all of a battler's moves fully
|
|||
}
|
||||
|
||||
TO_DO_BATTLE_TEST("Ether won't work if the selected move has all its PP")
|
||||
|
||||
TO_DO_BATTLE_TEST("Elixir can be used if at least one move is missing PP in any slot") // The test system can't currently test this, in a test the item is used without running useability checks
|
||||
/*
|
||||
{
|
||||
u8 move1PP;
|
||||
u8 move2PP;
|
||||
u8 move3PP;
|
||||
u8 move4PP;
|
||||
PARAMETRIZE { move1PP = 30; move2PP = 30; move3PP = 20; move4PP = 10; }
|
||||
PARAMETRIZE { move1PP = 40; move2PP = 20; move3PP = 20; move4PP = 10; }
|
||||
PARAMETRIZE { move1PP = 40; move2PP = 30; move3PP = 10; move4PP = 10; }
|
||||
PARAMETRIZE { move1PP = 40; move2PP = 30; move3PP = 20; move4PP = 0; }
|
||||
GIVEN {
|
||||
ASSUME(gItemsInfo[ITEM_ELIXIR].battleUsage == EFFECT_ITEM_RESTORE_PP);
|
||||
ASSUME(gItemsInfo[ITEM_ELIXIR].type == ITEM_USE_PARTY_MENU);
|
||||
PLAYER(SPECIES_WOBBUFFET) { MovesWithPP({MOVE_MEDITATE, move1PP}, {MOVE_AGILITY, move2PP}, {MOVE_PSYBEAM, move3PP}, {MOVE_TRICK, move4PP}); }
|
||||
OPPONENT(SPECIES_WOBBUFFET);
|
||||
} WHEN {
|
||||
TURN { USE_ITEM(player, ITEM_ELIXIR, partyIndex: 0); }
|
||||
} THEN {
|
||||
EXPECT_EQ(player->pp[0], 40);
|
||||
EXPECT_EQ(player->pp[1], 30);
|
||||
EXPECT_EQ(player->pp[2], 20);
|
||||
EXPECT_EQ(player->pp[3], 10);
|
||||
}
|
||||
}
|
||||
*/
|
||||
|
|
Loading…
Reference in a new issue