Turned Retaliate's effect into a side status
This commit is contained in:
parent
1f97198267
commit
3a25bce185
5 changed files with 6 additions and 14 deletions
|
@ -908,7 +908,5 @@ extern u8 gBattleControllerData[MAX_BATTLERS_COUNT];
|
|||
extern bool8 gHasFetchedBall;
|
||||
extern u8 gLastUsedBall;
|
||||
extern u16 gLastThrownBall;
|
||||
extern bool8 gCanPlayerRetaliate;
|
||||
extern bool8 gCanOpponentRetaliate;
|
||||
|
||||
#endif // GUARD_BATTLE_H
|
||||
|
|
|
@ -220,6 +220,7 @@
|
|||
#define SIDE_STATUS_WIDE_GUARD (1 << 19)
|
||||
#define SIDE_STATUS_CRAFTY_SHIELD (1 << 20)
|
||||
#define SIDE_STATUS_MAT_BLOCK (1 << 21)
|
||||
#define SIDE_STATUS_RETALIATE (1 << 22)
|
||||
|
||||
#define SIDE_STATUS_HAZARDS_ANY (SIDE_STATUS_SPIKES | SIDE_STATUS_STICKY_WEB | SIDE_STATUS_TOXIC_SPIKES | SIDE_STATUS_STEALTH_ROCK)
|
||||
#define SIDE_STATUS_SCREEN_ANY (SIDE_STATUS_REFLECT | SIDE_STATUS_LIGHTSCREEN | SIDE_STATUS_AURORA_VEIL)
|
||||
|
|
|
@ -231,8 +231,6 @@ EWRAM_DATA struct TotemBoost gTotemBoosts[MAX_BATTLERS_COUNT] = {0};
|
|||
EWRAM_DATA bool8 gHasFetchedBall = FALSE;
|
||||
EWRAM_DATA u8 gLastUsedBall = 0;
|
||||
EWRAM_DATA u16 gLastThrownBall = 0;
|
||||
EWRAM_DATA bool8 gCanPlayerRetaliate = FALSE;
|
||||
EWRAM_DATA bool8 gCanOpponentRetaliate = FALSE;
|
||||
|
||||
// IWRAM common vars
|
||||
void (*gPreBattleCallback1)(void);
|
||||
|
@ -2878,9 +2876,6 @@ static void BattleStartClearSetData(void)
|
|||
gHasFetchedBall = FALSE;
|
||||
gLastUsedBall = 0;
|
||||
|
||||
gCanPlayerRetaliate = FALSE;
|
||||
gCanOpponentRetaliate = FALSE;
|
||||
|
||||
gBattlerAttacker = 0;
|
||||
gBattlerTarget = 0;
|
||||
gBattleWeather = 0;
|
||||
|
|
|
@ -3499,14 +3499,14 @@ static void Cmd_tryfaintmon(void)
|
|||
if (gBattleResults.playerFaintCounter < 0xFF)
|
||||
gBattleResults.playerFaintCounter++;
|
||||
AdjustFriendshipOnBattleFaint(gActiveBattler);
|
||||
gCanPlayerRetaliate = TRUE;
|
||||
gSideStatuses[0] |= SIDE_STATUS_RETALIATE;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (gBattleResults.opponentFaintCounter < 0xFF)
|
||||
gBattleResults.opponentFaintCounter++;
|
||||
gBattleResults.lastOpponentSpecies = GetMonData(&gEnemyParty[gBattlerPartyIndexes[gActiveBattler]], MON_DATA_SPECIES, NULL);
|
||||
gCanOpponentRetaliate = TRUE;
|
||||
gSideStatuses[1] |= SIDE_STATUS_RETALIATE;
|
||||
}
|
||||
if ((gHitMarker & HITMARKER_DESTINYBOND) && gBattleMons[gBattlerAttacker].hp != 0)
|
||||
{
|
||||
|
|
|
@ -7681,6 +7681,7 @@ static u32 CalcMoveBasePowerAfterModifiers(u16 move, u8 battlerAtk, u8 battlerDe
|
|||
u16 basePower = CalcMoveBasePower(move, battlerAtk, battlerDef);
|
||||
u16 holdEffectModifier;
|
||||
u16 modifier = UQ_4_12(1.0);
|
||||
u32 atkSide = GET_BATTLER_SIDE(battlerAtk);
|
||||
|
||||
// attacker's abilities
|
||||
switch (GetBattlerAbility(battlerAtk))
|
||||
|
@ -7933,13 +7934,10 @@ static u32 CalcMoveBasePowerAfterModifiers(u16 move, u8 battlerAtk, u8 battlerDe
|
|||
MulModifier(&modifier, UQ_4_12(2.0));
|
||||
break;
|
||||
case EFFECT_RETALIATE:
|
||||
if (gCanPlayerRetaliate || gCanOpponentRetaliate)
|
||||
if (gSideStatuses[atkSide] & SIDE_STATUS_RETALIATE)
|
||||
{
|
||||
MulModifier(&modifier, UQ_4_12(2.0));
|
||||
if (gCanPlayerRetaliate)
|
||||
gCanPlayerRetaliate = FALSE;
|
||||
else if (gCanOpponentRetaliate)
|
||||
gCanOpponentRetaliate = FALSE;
|
||||
gSideStatuses[atkSide] &= ~SIDE_STATUS_RETALIATE;
|
||||
}
|
||||
break;
|
||||
case EFFECT_SOLARBEAM:
|
||||
|
|
Loading…
Reference in a new issue