Converted Stance Change to proper Form Change + Tests (#5749)
This commit is contained in:
parent
7e5327864e
commit
4635f0e0f8
5 changed files with 115 additions and 33 deletions
|
@ -134,8 +134,14 @@
|
||||||
// param1: amount of days
|
// param1: amount of days
|
||||||
#define FORM_CHANGE_DAYS_PASSED 23
|
#define FORM_CHANGE_DAYS_PASSED 23
|
||||||
|
|
||||||
// Form change for Aegislash
|
// Form change that activates before using a move.
|
||||||
#define FORM_CHANGE_BATTLE_ATTACK 24
|
// param1: move to check
|
||||||
#define FORM_CHANGE_BATTLE_KINGS_SHIELD 25
|
// param2: ability to check, optional
|
||||||
|
#define FORM_CHANGE_BATTLE_BEFORE_MOVE 24
|
||||||
|
|
||||||
|
// Form change that activates before using a specific move category.
|
||||||
|
// param1: move category to check
|
||||||
|
// param2: ability to check, optional
|
||||||
|
#define FORM_CHANGE_BATTLE_BEFORE_MOVE_CATEGORY 25
|
||||||
|
|
||||||
#endif // GUARD_CONSTANTS_FORM_CHANGE_TYPES_H
|
#endif // GUARD_CONSTANTS_FORM_CHANGE_TYPES_H
|
||||||
|
|
|
@ -1125,29 +1125,14 @@ static bool32 NoTargetPresent(u8 battler, u32 move)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool32 TryAegiFormChange(void)
|
static bool32 TryFormChangeBeforeMove(void)
|
||||||
{
|
{
|
||||||
// Only Aegislash with Stance Change can transform, transformed mons cannot.
|
bool32 result = TryBattleFormChange(gBattlerAttacker, FORM_CHANGE_BATTLE_BEFORE_MOVE);
|
||||||
if (GetBattlerAbility(gBattlerAttacker) != ABILITY_STANCE_CHANGE
|
if (!result)
|
||||||
|| gBattleMons[gBattlerAttacker].status2 & STATUS2_TRANSFORMED)
|
result = TryBattleFormChange(gBattlerAttacker, FORM_CHANGE_BATTLE_BEFORE_MOVE_CATEGORY);
|
||||||
|
if (!result)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
switch (gBattleMons[gBattlerAttacker].species)
|
|
||||||
{
|
|
||||||
default:
|
|
||||||
return FALSE;
|
|
||||||
case SPECIES_AEGISLASH_SHIELD: // Shield -> Blade
|
|
||||||
if (IS_MOVE_STATUS(gCurrentMove))
|
|
||||||
return FALSE;
|
|
||||||
TryBattleFormChange(gBattlerAttacker, FORM_CHANGE_BATTLE_ATTACK);
|
|
||||||
break;
|
|
||||||
case SPECIES_AEGISLASH_BLADE: // Blade -> Shield
|
|
||||||
if (gCurrentMove != MOVE_KINGS_SHIELD)
|
|
||||||
return FALSE;
|
|
||||||
TryBattleFormChange(gBattlerAttacker, FORM_CHANGE_BATTLE_KINGS_SHIELD);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
BattleScriptPushCursor();
|
BattleScriptPushCursor();
|
||||||
gBattlescriptCurrInstr = BattleScript_AttackerFormChange;
|
gBattlescriptCurrInstr = BattleScript_AttackerFormChange;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -1221,7 +1206,7 @@ static void Cmd_attackcanceler(void)
|
||||||
gBattlescriptCurrInstr = BattleScript_MoveEnd;
|
gBattlescriptCurrInstr = BattleScript_MoveEnd;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (B_STANCE_CHANGE_FAIL < GEN_7 && TryAegiFormChange())
|
if (B_STANCE_CHANGE_FAIL < GEN_7 && TryFormChangeBeforeMove())
|
||||||
return;
|
return;
|
||||||
if (AtkCanceller_UnableToUseMove(moveType))
|
if (AtkCanceller_UnableToUseMove(moveType))
|
||||||
return;
|
return;
|
||||||
|
@ -1282,7 +1267,7 @@ static void Cmd_attackcanceler(void)
|
||||||
gMoveResultFlags |= MOVE_RESULT_MISSED;
|
gMoveResultFlags |= MOVE_RESULT_MISSED;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (B_STANCE_CHANGE_FAIL >= GEN_7 && TryAegiFormChange())
|
if (B_STANCE_CHANGE_FAIL >= GEN_7 && TryFormChangeBeforeMove())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
gHitMarker &= ~HITMARKER_ALLOW_NO_PP;
|
gHitMarker &= ~HITMARKER_ALLOW_NO_PP;
|
||||||
|
|
|
@ -10988,9 +10988,15 @@ u16 GetBattleFormChangeTargetSpecies(u32 battler, u16 method)
|
||||||
if (GetBattlerTeraType(battler) == formChanges[i].param1)
|
if (GetBattlerTeraType(battler) == formChanges[i].param1)
|
||||||
targetSpecies = formChanges[i].targetSpecies;
|
targetSpecies = formChanges[i].targetSpecies;
|
||||||
break;
|
break;
|
||||||
case FORM_CHANGE_BATTLE_ATTACK:
|
case FORM_CHANGE_BATTLE_BEFORE_MOVE:
|
||||||
case FORM_CHANGE_BATTLE_KINGS_SHIELD:
|
if (formChanges[i].param1 == gCurrentMove
|
||||||
targetSpecies = formChanges[i].targetSpecies;
|
&& (formChanges[i].param2 == ABILITY_NONE || formChanges[i].param2 == GetBattlerAbility(battler)))
|
||||||
|
targetSpecies = formChanges[i].targetSpecies;
|
||||||
|
break;
|
||||||
|
case FORM_CHANGE_BATTLE_BEFORE_MOVE_CATEGORY:
|
||||||
|
if (formChanges[i].param1 == GetBattleMoveCategory(gCurrentMove)
|
||||||
|
&& (formChanges[i].param2 == ABILITY_NONE || formChanges[i].param2 == GetBattlerAbility(battler)))
|
||||||
|
targetSpecies = formChanges[i].targetSpecies;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -789,11 +789,12 @@ static const struct FormChange sFurfrouFormChangeTable[] = {
|
||||||
|
|
||||||
#if P_FAMILY_HONEDGE
|
#if P_FAMILY_HONEDGE
|
||||||
static const struct FormChange sAegislashFormChangeTable[] = {
|
static const struct FormChange sAegislashFormChangeTable[] = {
|
||||||
{FORM_CHANGE_BATTLE_ATTACK, SPECIES_AEGISLASH_BLADE},
|
{FORM_CHANGE_BATTLE_BEFORE_MOVE_CATEGORY, SPECIES_AEGISLASH_BLADE, DAMAGE_CATEGORY_PHYSICAL, ABILITY_STANCE_CHANGE},
|
||||||
{FORM_CHANGE_BATTLE_KINGS_SHIELD, SPECIES_AEGISLASH_SHIELD},
|
{FORM_CHANGE_BATTLE_BEFORE_MOVE_CATEGORY, SPECIES_AEGISLASH_BLADE, DAMAGE_CATEGORY_SPECIAL, ABILITY_STANCE_CHANGE},
|
||||||
{FORM_CHANGE_BATTLE_SWITCH, SPECIES_AEGISLASH_SHIELD},
|
{FORM_CHANGE_BATTLE_BEFORE_MOVE, SPECIES_AEGISLASH_SHIELD, MOVE_KINGS_SHIELD, ABILITY_STANCE_CHANGE},
|
||||||
{FORM_CHANGE_FAINT, SPECIES_AEGISLASH_SHIELD},
|
{FORM_CHANGE_BATTLE_SWITCH, SPECIES_AEGISLASH_SHIELD},
|
||||||
{FORM_CHANGE_END_BATTLE, SPECIES_AEGISLASH_SHIELD},
|
{FORM_CHANGE_FAINT, SPECIES_AEGISLASH_SHIELD},
|
||||||
|
{FORM_CHANGE_END_BATTLE, SPECIES_AEGISLASH_SHIELD},
|
||||||
{FORM_CHANGE_TERMINATOR},
|
{FORM_CHANGE_TERMINATOR},
|
||||||
};
|
};
|
||||||
#endif //P_FAMILY_HONEDGE
|
#endif //P_FAMILY_HONEDGE
|
||||||
|
|
84
test/battle/ability/stance_change.c
Normal file
84
test/battle/ability/stance_change.c
Normal file
|
@ -0,0 +1,84 @@
|
||||||
|
#include "global.h"
|
||||||
|
#include "test/battle.h"
|
||||||
|
|
||||||
|
|
||||||
|
SINGLE_BATTLE_TEST("Stance Change changes Aegislash from Shield to Blade when using a damaging move")
|
||||||
|
{
|
||||||
|
u16 move;
|
||||||
|
PARAMETRIZE { move = MOVE_TACKLE; }
|
||||||
|
PARAMETRIZE { move = MOVE_SWIFT; }
|
||||||
|
PARAMETRIZE { move = MOVE_GROWL; }
|
||||||
|
GIVEN {
|
||||||
|
PLAYER(SPECIES_AEGISLASH_SHIELD);
|
||||||
|
OPPONENT(SPECIES_WOBBUFFET);
|
||||||
|
} WHEN {
|
||||||
|
TURN { MOVE(player, move); }
|
||||||
|
} SCENE {
|
||||||
|
if (move != MOVE_GROWL) {
|
||||||
|
ABILITY_POPUP(player, ABILITY_STANCE_CHANGE);
|
||||||
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
||||||
|
} else {
|
||||||
|
NONE_OF {
|
||||||
|
ABILITY_POPUP(player, ABILITY_STANCE_CHANGE);
|
||||||
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
||||||
|
} THEN {
|
||||||
|
if (move != MOVE_GROWL)
|
||||||
|
EXPECT_EQ(player->species, SPECIES_AEGISLASH_BLADE);
|
||||||
|
else
|
||||||
|
EXPECT_EQ(player->species, SPECIES_AEGISLASH_SHIELD);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
SINGLE_BATTLE_TEST("Stance Change changes Aegislash from Blade to Shield when using King's Shield")
|
||||||
|
{
|
||||||
|
u16 move;
|
||||||
|
PARAMETRIZE { move = MOVE_PROTECT; }
|
||||||
|
PARAMETRIZE { move = MOVE_KINGS_SHIELD; }
|
||||||
|
GIVEN {
|
||||||
|
PLAYER(SPECIES_AEGISLASH_BLADE);
|
||||||
|
OPPONENT(SPECIES_WOBBUFFET);
|
||||||
|
} WHEN {
|
||||||
|
TURN { MOVE(player, move); }
|
||||||
|
} SCENE {
|
||||||
|
if (move == MOVE_KINGS_SHIELD) {
|
||||||
|
ABILITY_POPUP(player, ABILITY_STANCE_CHANGE);
|
||||||
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
||||||
|
} else {
|
||||||
|
NONE_OF {
|
||||||
|
ABILITY_POPUP(player, ABILITY_STANCE_CHANGE);
|
||||||
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
||||||
|
} THEN {
|
||||||
|
if (move == MOVE_KINGS_SHIELD)
|
||||||
|
EXPECT_EQ(player->species, SPECIES_AEGISLASH_SHIELD);
|
||||||
|
else
|
||||||
|
EXPECT_EQ(player->species, SPECIES_AEGISLASH_BLADE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
SINGLE_BATTLE_TEST("Stance Change doesn't change Aegislash to Shield if King's Shield is called by a different move - Sleep Talk")
|
||||||
|
{
|
||||||
|
KNOWN_FAILING; // Currently does change form
|
||||||
|
GIVEN {
|
||||||
|
ASSUME(gMovesInfo[MOVE_SLEEP_TALK].effect == EFFECT_SLEEP_TALK);
|
||||||
|
PLAYER(SPECIES_AEGISLASH_BLADE) { Moves(MOVE_KINGS_SHIELD, MOVE_SLEEP_TALK); Status1(STATUS1_SLEEP_TURN(3)); }
|
||||||
|
OPPONENT(SPECIES_WOBBUFFET);
|
||||||
|
} WHEN {
|
||||||
|
TURN { MOVE(player, MOVE_SLEEP_TALK); }
|
||||||
|
} SCENE {
|
||||||
|
NONE_OF {
|
||||||
|
ABILITY_POPUP(player, ABILITY_STANCE_CHANGE);
|
||||||
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
||||||
|
}
|
||||||
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_KINGS_SHIELD, player);
|
||||||
|
} THEN {
|
||||||
|
EXPECT_EQ(player->species, SPECIES_AEGISLASH_BLADE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TO_DO_BATTLE_TEST("Stance Change doesn't change Aegislash to Shield if King's Shield is called by a different move - Me First");
|
Loading…
Reference in a new issue