Swapped webs don't trigger Defiant
Track the side that originally set Sticky Web, and if it matches the side the target of the speed drop is on, don't activate Defiant. Hard to tell if this is a bug or a feature in gen 8 - maybe the swapped webs are considered a "friendly" effect? Also, fix Sticky Web not activating Defiant.
This commit is contained in:
parent
499fb8071d
commit
a89ce0c38a
5 changed files with 30 additions and 18 deletions
|
@ -6712,6 +6712,7 @@ BattleScript_ToxicSpikesPoisoned::
|
||||||
BattleScript_StickyWebOnSwitchIn::
|
BattleScript_StickyWebOnSwitchIn::
|
||||||
savetarget
|
savetarget
|
||||||
copybyte gBattlerTarget, sBATTLER
|
copybyte gBattlerTarget, sBATTLER
|
||||||
|
setbyte sSTICKY_WEB_STAT_DROP, 1
|
||||||
printstring STRINGID_STICKYWEBSWITCHIN
|
printstring STRINGID_STICKYWEBSWITCHIN
|
||||||
waitmessage B_WAIT_TIME_LONG
|
waitmessage B_WAIT_TIME_LONG
|
||||||
jumpifability BS_TARGET, ABILITY_MIRROR_ARMOR, BattleScript_MirrorArmorReflectStickyWeb
|
jumpifability BS_TARGET, ABILITY_MIRROR_ARMOR, BattleScript_MirrorArmorReflectStickyWeb
|
||||||
|
|
|
@ -211,6 +211,7 @@ struct SideTimer
|
||||||
u8 toxicSpikesAmount;
|
u8 toxicSpikesAmount;
|
||||||
u8 stealthRockAmount;
|
u8 stealthRockAmount;
|
||||||
u8 stickyWebAmount;
|
u8 stickyWebAmount;
|
||||||
|
u8 stickyWebBattlerSide; // Used for Court Change
|
||||||
u8 auroraVeilTimer;
|
u8 auroraVeilTimer;
|
||||||
u8 auroraVeilBattlerId;
|
u8 auroraVeilBattlerId;
|
||||||
u8 tailwindTimer;
|
u8 tailwindTimer;
|
||||||
|
@ -704,6 +705,7 @@ struct BattleScripting
|
||||||
u16 abilityPopupOverwrite;
|
u16 abilityPopupOverwrite;
|
||||||
u8 switchCase; // Special switching conditions, eg. red card
|
u8 switchCase; // Special switching conditions, eg. red card
|
||||||
u8 overrideBerryRequirements;
|
u8 overrideBerryRequirements;
|
||||||
|
u8 stickyWebStatDrop; // To prevent Defiant activating on a Court Change'd Sticky Web
|
||||||
};
|
};
|
||||||
|
|
||||||
// rom_80A5C6C
|
// rom_80A5C6C
|
||||||
|
|
|
@ -39,6 +39,7 @@
|
||||||
#define sABILITY_OVERWRITE gBattleScripting + 0x34
|
#define sABILITY_OVERWRITE gBattleScripting + 0x34
|
||||||
#define sSWITCH_CASE gBattleScripting + 0x36
|
#define sSWITCH_CASE gBattleScripting + 0x36
|
||||||
#define sBERRY_OVERRIDE gBattleScripting + 0x37
|
#define sBERRY_OVERRIDE gBattleScripting + 0x37
|
||||||
|
#define sSTICKY_WEB_STAT_DROP gBattleScripting + 0x38
|
||||||
|
|
||||||
#define cMULTISTRING_CHOOSER gBattleCommunication + 5
|
#define cMULTISTRING_CHOOSER gBattleCommunication + 5
|
||||||
#define cMISS_TYPE gBattleCommunication + 6
|
#define cMISS_TYPE gBattleCommunication + 6
|
||||||
|
|
|
@ -7536,30 +7536,30 @@ static bool32 IsRototillerAffected(u32 battlerId)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define COURTCHANGE_SWAP(status, structField, temp) \
|
#define COURTCHANGE_SWAP(status, structField, temp) \
|
||||||
{ \
|
{ \
|
||||||
temp = gSideStatuses[B_SIDE_PLAYER]; \
|
temp = gSideStatuses[B_SIDE_PLAYER]; \
|
||||||
if (gSideStatuses[B_SIDE_OPPONENT] & status) \
|
if (gSideStatuses[B_SIDE_OPPONENT] & status) \
|
||||||
gSideStatuses[B_SIDE_PLAYER] |= status; \
|
gSideStatuses[B_SIDE_PLAYER] |= status; \
|
||||||
else \
|
else \
|
||||||
gSideStatuses[B_SIDE_PLAYER] &= ~(status); \
|
gSideStatuses[B_SIDE_PLAYER] &= ~(status); \
|
||||||
if (temp & status) \
|
if (temp & status) \
|
||||||
gSideStatuses[B_SIDE_OPPONENT] |= status; \
|
gSideStatuses[B_SIDE_OPPONENT] |= status; \
|
||||||
else \
|
else \
|
||||||
gSideStatuses[B_SIDE_OPPONENT] &= ~(status); \
|
gSideStatuses[B_SIDE_OPPONENT] &= ~(status); \
|
||||||
SWAP(sideTimer0->structField, sideTimer1->structField, temp);\
|
SWAP(sideTimerPlayer->structField, sideTimerOpp->structField, temp);\
|
||||||
} \
|
} \
|
||||||
|
|
||||||
#define UPDATE_COURTCHANGED_BATTLER(structField)\
|
#define UPDATE_COURTCHANGED_BATTLER(structField)\
|
||||||
{ \
|
{ \
|
||||||
sideTimer0->structField ^= BIT_SIDE; \
|
sideTimerPlayer->structField ^= BIT_SIDE; \
|
||||||
sideTimer1->structField ^= BIT_SIDE; \
|
sideTimerOpp->structField ^= BIT_SIDE; \
|
||||||
} \
|
} \
|
||||||
|
|
||||||
static bool32 CourtChangeSwapSideStatuses(void)
|
static bool32 CourtChangeSwapSideStatuses(void)
|
||||||
{
|
{
|
||||||
struct SideTimer *sideTimer0 = &gSideTimers[B_SIDE_PLAYER];
|
struct SideTimer *sideTimerPlayer = &gSideTimers[B_SIDE_PLAYER];
|
||||||
struct SideTimer *sideTimer1 = &gSideTimers[B_SIDE_OPPONENT];
|
struct SideTimer *sideTimerOpp = &gSideTimers[B_SIDE_OPPONENT];
|
||||||
u32 temp;
|
u32 temp;
|
||||||
|
|
||||||
// TODO: add Pledge-related effects
|
// TODO: add Pledge-related effects
|
||||||
|
@ -7588,6 +7588,9 @@ static bool32 CourtChangeSwapSideStatuses(void)
|
||||||
UPDATE_COURTCHANGED_BATTLER(auroraVeilBattlerId);
|
UPDATE_COURTCHANGED_BATTLER(auroraVeilBattlerId);
|
||||||
UPDATE_COURTCHANGED_BATTLER(tailwindBattlerId);
|
UPDATE_COURTCHANGED_BATTLER(tailwindBattlerId);
|
||||||
UPDATE_COURTCHANGED_BATTLER(luckyChantBattlerId);
|
UPDATE_COURTCHANGED_BATTLER(luckyChantBattlerId);
|
||||||
|
|
||||||
|
// Track which side originally set the Sticky Web
|
||||||
|
SWAP(sideTimerPlayer->stickyWebBattlerSide, sideTimerOpp->stickyWebBattlerSide, temp);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Cmd_various(void)
|
static void Cmd_various(void)
|
||||||
|
@ -11996,6 +11999,7 @@ static void Cmd_recoverbasedonsunlight(void)
|
||||||
static void Cmd_setstickyweb(void)
|
static void Cmd_setstickyweb(void)
|
||||||
{
|
{
|
||||||
u8 targetSide = GetBattlerSide(gBattlerTarget);
|
u8 targetSide = GetBattlerSide(gBattlerTarget);
|
||||||
|
|
||||||
if (gSideStatuses[targetSide] & SIDE_STATUS_STICKY_WEB)
|
if (gSideStatuses[targetSide] & SIDE_STATUS_STICKY_WEB)
|
||||||
{
|
{
|
||||||
gBattlescriptCurrInstr = T1_READ_PTR(gBattlescriptCurrInstr + 1);
|
gBattlescriptCurrInstr = T1_READ_PTR(gBattlescriptCurrInstr + 1);
|
||||||
|
@ -12003,6 +12007,7 @@ static void Cmd_setstickyweb(void)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
gSideStatuses[targetSide] |= SIDE_STATUS_STICKY_WEB;
|
gSideStatuses[targetSide] |= SIDE_STATUS_STICKY_WEB;
|
||||||
|
gSideTimers[targetSide].stickyWebBattlerSide = GetBattlerSide(gBattlerAttacker); // For Court Change/Defiant - set this to the user's side
|
||||||
gSideTimers[targetSide].stickyWebAmount = 1;
|
gSideTimers[targetSide].stickyWebAmount = 1;
|
||||||
gBattleStruct->stickyWebUser = gBattlerAttacker; // For Mirror Armor
|
gBattleStruct->stickyWebUser = gBattlerAttacker; // For Mirror Armor
|
||||||
gBattlescriptCurrInstr += 5;
|
gBattlescriptCurrInstr += 5;
|
||||||
|
|
|
@ -1453,6 +1453,7 @@ bool8 WasUnableToUseMove(u8 battler)
|
||||||
|
|
||||||
void PrepareStringBattle(u16 stringId, u8 battler)
|
void PrepareStringBattle(u16 stringId, u8 battler)
|
||||||
{
|
{
|
||||||
|
u32 targetSide = GetBattlerSide(gBattlerTarget);
|
||||||
// Support for Contrary ability.
|
// Support for Contrary ability.
|
||||||
// If a move attempted to raise stat - print "won't increase".
|
// If a move attempted to raise stat - print "won't increase".
|
||||||
// If a move attempted to lower stat - print "won't decrease".
|
// If a move attempted to lower stat - print "won't decrease".
|
||||||
|
@ -1471,8 +1472,10 @@ void PrepareStringBattle(u16 stringId, u8 battler)
|
||||||
&& ((GetBattlerAbility(gBattlerTarget) == ABILITY_DEFIANT && CompareStat(gBattlerTarget, STAT_ATK, MAX_STAT_STAGE, CMP_LESS_THAN))
|
&& ((GetBattlerAbility(gBattlerTarget) == ABILITY_DEFIANT && CompareStat(gBattlerTarget, STAT_ATK, MAX_STAT_STAGE, CMP_LESS_THAN))
|
||||||
|| (GetBattlerAbility(gBattlerTarget) == ABILITY_COMPETITIVE && CompareStat(gBattlerTarget, STAT_SPATK, MAX_STAT_STAGE, CMP_LESS_THAN)))
|
|| (GetBattlerAbility(gBattlerTarget) == ABILITY_COMPETITIVE && CompareStat(gBattlerTarget, STAT_SPATK, MAX_STAT_STAGE, CMP_LESS_THAN)))
|
||||||
&& gSpecialStatuses[gBattlerTarget].changedStatsBattlerId != BATTLE_PARTNER(gBattlerTarget)
|
&& gSpecialStatuses[gBattlerTarget].changedStatsBattlerId != BATTLE_PARTNER(gBattlerTarget)
|
||||||
&& gSpecialStatuses[gBattlerTarget].changedStatsBattlerId != gBattlerTarget)
|
// && gSpecialStatuses[gBattlerTarget].changedStatsBattlerId != gBattlerTarget) // Why was this here? Needs investigating
|
||||||
|
&& !(gBattleScripting.stickyWebStatDrop == 1 && gSideTimers[targetSide].stickyWebBattlerSide == targetSide)) // Sticky Web must have been set by the foe
|
||||||
{
|
{
|
||||||
|
gBattleScripting.stickyWebStatDrop = 0;
|
||||||
gBattlerAbility = gBattlerTarget;
|
gBattlerAbility = gBattlerTarget;
|
||||||
BattleScriptPushCursor();
|
BattleScriptPushCursor();
|
||||||
gBattlescriptCurrInstr = BattleScript_DefiantActivates;
|
gBattlescriptCurrInstr = BattleScript_DefiantActivates;
|
||||||
|
|
Loading…
Reference in a new issue