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:
BuffelSaft 2021-11-23 22:54:30 +13:00
parent 499fb8071d
commit a89ce0c38a
5 changed files with 30 additions and 18 deletions

View file

@ -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

View file

@ -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

View file

@ -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

View file

@ -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;

View file

@ -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;