implemented all status1 and status2 G-Max Moves: Befuddle, Volt Crash, Malodor, Stun Shock, Gold Rush, Cuddle, Terror, Meltdown, Smite
This commit is contained in:
parent
0908129c84
commit
da24b717e4
10 changed files with 269 additions and 16 deletions
|
@ -2237,6 +2237,16 @@
|
||||||
various 0, VARIOUS_DAMAGE_NON_TYPES
|
various 0, VARIOUS_DAMAGE_NON_TYPES
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
|
.macro trysetstatus1, ptr:req
|
||||||
|
various 0, VARIOUS_TRY_SET_STATUS1
|
||||||
|
.4byte \ptr
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro trysetstatus2, ptr:req
|
||||||
|
various 0, VARIOUS_TRY_SET_STATUS2
|
||||||
|
.4byte \ptr
|
||||||
|
.endm
|
||||||
|
|
||||||
@ Tries to increase or decrease a battler's stat's stat stage by a specified amount. If impossible, jumps to \script.
|
@ Tries to increase or decrease a battler's stat's stat stage by a specified amount. If impossible, jumps to \script.
|
||||||
.macro modifybattlerstatstage battler:req, stat:req, mode:req, amount:req, script:req, animation:req, customString
|
.macro modifybattlerstatstage battler:req, stat:req, mode:req, amount:req, script:req, animation:req, customString
|
||||||
|
|
||||||
|
|
|
@ -10358,7 +10358,7 @@ BattleScript_EffectMaxMove::
|
||||||
tryfaintmon BS_TARGET
|
tryfaintmon BS_TARGET
|
||||||
goto BattleScript_MoveEnd
|
goto BattleScript_MoveEnd
|
||||||
|
|
||||||
BattleScript_EffectRaiseSideStats::
|
BattleScript_EffectRaiseStatAllies::
|
||||||
savetarget
|
savetarget
|
||||||
setbyte gBattlerTarget, 0
|
setbyte gBattlerTarget, 0
|
||||||
BattleScript_RaiseSideStatsLoop:
|
BattleScript_RaiseSideStatsLoop:
|
||||||
|
@ -10378,7 +10378,7 @@ BattleScript_RaiseSideStatsEnd:
|
||||||
restoretarget
|
restoretarget
|
||||||
return
|
return
|
||||||
|
|
||||||
BattleScript_EffectLowerSideStats::
|
BattleScript_EffectLowerStatFoes::
|
||||||
savetarget
|
savetarget
|
||||||
setbyte gBattlerTarget, 0
|
setbyte gBattlerTarget, 0
|
||||||
BattleScript_LowerSideStatsLoop:
|
BattleScript_LowerSideStatsLoop:
|
||||||
|
@ -10460,6 +10460,57 @@ BattleScript_EffectTryReducePP::
|
||||||
waitmessage B_WAIT_TIME_LONG
|
waitmessage B_WAIT_TIME_LONG
|
||||||
goto BattleScript_MoveEnd
|
goto BattleScript_MoveEnd
|
||||||
|
|
||||||
|
BattleScript_EffectStatus1Foes::
|
||||||
|
savetarget
|
||||||
|
setbyte gBattlerTarget, 0
|
||||||
|
BattleScript_Status1FoesLoop:
|
||||||
|
jumpiftargetally BattleScript_Status1FoesIncrement
|
||||||
|
jumpiftargetabsent BattleScript_Status1FoesIncrement
|
||||||
|
trysetstatus1 BattleScript_Status1FoesIncrement
|
||||||
|
statusanimation BS_TARGET
|
||||||
|
updatestatusicon BS_TARGET
|
||||||
|
printfromtable gStatusConditionsStringIds
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
goto BattleScript_UpdateEffectStatusIconRet
|
||||||
|
BattleScript_Status1FoesIncrement:
|
||||||
|
addbyte gBattlerTarget, 1
|
||||||
|
jumpifbytenotequal gBattlerTarget, gBattlersCount, BattleScript_Status1FoesLoop
|
||||||
|
BattleScript_Status1FoesEnd:
|
||||||
|
restoretarget
|
||||||
|
goto BattleScript_MoveEnd
|
||||||
|
|
||||||
|
BattleScript_EffectStatus2Foes::
|
||||||
|
savetarget
|
||||||
|
setbyte gBattlerTarget, 0
|
||||||
|
BattleScript_Status2FoesLoop:
|
||||||
|
jumpiftargetally BattleScript_Status2FoesIncrement
|
||||||
|
jumpiftargetabsent BattleScript_Status2FoesIncrement
|
||||||
|
trysetstatus2 BattleScript_Status2FoesIncrement
|
||||||
|
jumpifbyte CMP_EQUAL, gBattleCommunication, 1, BattleScript_DoConfuseAnim
|
||||||
|
jumpifbyte CMP_EQUAL, gBattleCommunication, 2, BattleScript_DoInfatuationAnim
|
||||||
|
BattleScript_Status2FoesPrintMessage:
|
||||||
|
printfromtable gStatus2StringIds
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
BattleScript_Status2FoesIncrement:
|
||||||
|
addbyte gBattlerTarget, 1
|
||||||
|
jumpifbytenotequal gBattlerTarget, gBattlersCount, BattleScript_Status2FoesLoop
|
||||||
|
BattleScript_Status2FoesEnd:
|
||||||
|
restoretarget
|
||||||
|
goto BattleScript_MoveEnd
|
||||||
|
|
||||||
|
BattleScript_DoConfuseAnim:
|
||||||
|
status2animation BS_TARGET, STATUS2_CONFUSION
|
||||||
|
goto BattleScript_Status2FoesPrintMessage
|
||||||
|
|
||||||
|
BattleScript_DoInfatuationAnim:
|
||||||
|
status2animation BS_TARGET, STATUS2_INFATUATION
|
||||||
|
goto BattleScript_Status2FoesPrintMessage
|
||||||
|
|
||||||
|
BattleScript_TormentEnds::
|
||||||
|
printstring STRINGID_TORMENTEDNOMORE
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
end2
|
||||||
|
|
||||||
BattleScript_PokemonCantUseTheMove::
|
BattleScript_PokemonCantUseTheMove::
|
||||||
attackstring
|
attackstring
|
||||||
ppreduce
|
ppreduce
|
||||||
|
|
|
@ -96,6 +96,7 @@ struct DisableStruct
|
||||||
u8 laserFocusTimer;
|
u8 laserFocusTimer;
|
||||||
u8 throatChopTimer;
|
u8 throatChopTimer;
|
||||||
u8 wrapTurns;
|
u8 wrapTurns;
|
||||||
|
u8 tormentTimer:4; // used for G-Max Meltdown
|
||||||
u8 usedMoves:4;
|
u8 usedMoves:4;
|
||||||
u8 noRetreat:1;
|
u8 noRetreat:1;
|
||||||
u8 tarShot:1;
|
u8 tarShot:1;
|
||||||
|
|
|
@ -58,7 +58,8 @@ u16 GetMaxMove(u16 battlerId, u16 baseMove);
|
||||||
u8 GetMaxMovePower(u16 move);
|
u8 GetMaxMovePower(u16 move);
|
||||||
bool8 IsMaxMove(u16 move);
|
bool8 IsMaxMove(u16 move);
|
||||||
const u8 *GetMaxMoveName(u16 move);
|
const u8 *GetMaxMoveName(u16 move);
|
||||||
void ChooseDamageNonTypesString(u8 move);
|
void ChooseDamageNonTypesString(u8 type);
|
||||||
|
u32 GetMaxMoveStatusEffect(u16 move);
|
||||||
u16 SetMaxMoveEffect(u16 move);
|
u16 SetMaxMoveEffect(u16 move);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -465,8 +465,8 @@ extern const u8 BattleScript_HealReplacementZMove[];
|
||||||
extern const u8 BattleScript_EffectExtremeEvoboost[];
|
extern const u8 BattleScript_EffectExtremeEvoboost[];
|
||||||
|
|
||||||
// max moves
|
// max moves
|
||||||
extern const u8 BattleScript_EffectRaiseSideStats[];
|
extern const u8 BattleScript_EffectRaiseStatAllies[];
|
||||||
extern const u8 BattleScript_EffectLowerSideStats[];
|
extern const u8 BattleScript_EffectLowerStatFoes[];
|
||||||
extern const u8 BattleScript_EffectSetWeather[];
|
extern const u8 BattleScript_EffectSetWeather[];
|
||||||
extern const u8 BattleScript_EffectSetTerrain[];
|
extern const u8 BattleScript_EffectSetTerrain[];
|
||||||
extern const u8 BattleScript_SteelsurgeActivates[];
|
extern const u8 BattleScript_SteelsurgeActivates[];
|
||||||
|
@ -478,5 +478,8 @@ extern const u8 BattleScript_EffectAuroraVeilSuccess[];
|
||||||
extern const u8 BattleScript_EffectGravitySuccess[];
|
extern const u8 BattleScript_EffectGravitySuccess[];
|
||||||
extern const u8 BattleScript_EffectYawnSuccess[];
|
extern const u8 BattleScript_EffectYawnSuccess[];
|
||||||
extern const u8 BattleScript_EffectTryReducePP[];
|
extern const u8 BattleScript_EffectTryReducePP[];
|
||||||
|
extern const u8 BattleScript_EffectStatus1Foes[];
|
||||||
|
extern const u8 BattleScript_EffectStatus2Foes[];
|
||||||
|
extern const u8 BattleScript_TormentEnds[];
|
||||||
|
|
||||||
#endif // GUARD_BATTLE_SCRIPTS_H
|
#endif // GUARD_BATTLE_SCRIPTS_H
|
|
@ -265,6 +265,8 @@
|
||||||
#define VARIOUS_JUMP_IF_TARGET_ABSENT 173
|
#define VARIOUS_JUMP_IF_TARGET_ABSENT 173
|
||||||
#define VARIOUS_SET_STEELSURGE 174
|
#define VARIOUS_SET_STEELSURGE 174
|
||||||
#define VARIOUS_DAMAGE_NON_TYPES 175
|
#define VARIOUS_DAMAGE_NON_TYPES 175
|
||||||
|
#define VARIOUS_TRY_SET_STATUS1 176
|
||||||
|
#define VARIOUS_TRY_SET_STATUS2 177
|
||||||
|
|
||||||
// Cmd_manipulatedamage
|
// Cmd_manipulatedamage
|
||||||
#define DMG_CHANGE_SIGN 0
|
#define DMG_CHANGE_SIGN 0
|
||||||
|
|
|
@ -99,7 +99,11 @@ bool8 ShouldUseMaxMove(u16 battlerId, u16 baseMove)
|
||||||
u16 GetMaxMove(u16 battlerId, u16 baseMove)
|
u16 GetMaxMove(u16 battlerId, u16 baseMove)
|
||||||
{
|
{
|
||||||
u16 move = baseMove;
|
u16 move = baseMove;
|
||||||
if (gBattleMoves[baseMove].split == SPLIT_STATUS)
|
if (baseMove == MOVE_STRUGGLE)
|
||||||
|
{
|
||||||
|
return MOVE_STRUGGLE;
|
||||||
|
}
|
||||||
|
else if (gBattleMoves[baseMove].split == SPLIT_STATUS)
|
||||||
{
|
{
|
||||||
move = MOVE_MAX_GUARD;
|
move = MOVE_MAX_GUARD;
|
||||||
}
|
}
|
||||||
|
@ -192,6 +196,45 @@ void ChooseDamageNonTypesString(u8 type)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Returns the status effect that should be applied by a G-Max Move.
|
||||||
|
u32 GetMaxMoveStatusEffect(u16 move)
|
||||||
|
{
|
||||||
|
u8 maxEffect = gBattleMoves[move].argument;
|
||||||
|
switch (maxEffect)
|
||||||
|
{
|
||||||
|
// Status 1
|
||||||
|
case MAX_EFFECT_PARALYZE_FOES:
|
||||||
|
return STATUS1_PARALYSIS;
|
||||||
|
case MAX_EFFECT_POISON_FOES:
|
||||||
|
return STATUS1_POISON;
|
||||||
|
case MAX_EFFECT_POISON_PARALYZE_FOES:
|
||||||
|
if (Random() % 2)
|
||||||
|
return STATUS1_POISON;
|
||||||
|
else
|
||||||
|
return STATUS1_PARALYSIS;
|
||||||
|
case MAX_EFFECT_EFFECT_SPORE_FOES:
|
||||||
|
{
|
||||||
|
u8 effect = Random() % 3;
|
||||||
|
if (effect == 0)
|
||||||
|
return STATUS1_PARALYSIS;
|
||||||
|
else if (effect == 1)
|
||||||
|
return STATUS1_POISON;
|
||||||
|
else
|
||||||
|
return STATUS1_SLEEP;
|
||||||
|
}
|
||||||
|
// Status 2
|
||||||
|
case MAX_EFFECT_CONFUSE_FOES:
|
||||||
|
case MAX_EFFECT_CONFUSE_FOES_PAY_DAY:
|
||||||
|
return STATUS2_CONFUSION;
|
||||||
|
case MAX_EFFECT_INFATUATE_FOES:
|
||||||
|
return STATUS2_INFATUATION;
|
||||||
|
case MAX_EFFECT_MEAN_LOOK:
|
||||||
|
return STATUS2_ESCAPE_PREVENTION;
|
||||||
|
case MAX_EFFECT_TORMENT_FOES:
|
||||||
|
return STATUS2_TORMENT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Activates the secondary effect of a Max Move.
|
// Activates the secondary effect of a Max Move.
|
||||||
u16 SetMaxMoveEffect(u16 move)
|
u16 SetMaxMoveEffect(u16 move)
|
||||||
{
|
{
|
||||||
|
@ -214,7 +257,7 @@ u16 SetMaxMoveEffect(u16 move)
|
||||||
// Max Effects are ordered by stat ID.
|
// Max Effects are ordered by stat ID.
|
||||||
SET_STATCHANGER(gBattleMoves[gCurrentMove].argument, 1, FALSE);
|
SET_STATCHANGER(gBattleMoves[gCurrentMove].argument, 1, FALSE);
|
||||||
BattleScriptPush(gBattlescriptCurrInstr + 1);
|
BattleScriptPush(gBattlescriptCurrInstr + 1);
|
||||||
gBattlescriptCurrInstr = BattleScript_EffectRaiseSideStats;
|
gBattlescriptCurrInstr = BattleScript_EffectRaiseStatAllies;
|
||||||
effect++;
|
effect++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -245,7 +288,7 @@ u16 SetMaxMoveEffect(u16 move)
|
||||||
}
|
}
|
||||||
SET_STATCHANGER(statId, stage, TRUE);
|
SET_STATCHANGER(statId, stage, TRUE);
|
||||||
BattleScriptPush(gBattlescriptCurrInstr + 1);
|
BattleScriptPush(gBattlescriptCurrInstr + 1);
|
||||||
gBattlescriptCurrInstr = BattleScript_EffectLowerSideStats;
|
gBattlescriptCurrInstr = BattleScript_EffectLowerStatFoes;
|
||||||
effect++;
|
effect++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -425,14 +468,7 @@ u16 SetMaxMoveEffect(u16 move)
|
||||||
}
|
}
|
||||||
case MAX_EFFECT_YAWN_FOE:
|
case MAX_EFFECT_YAWN_FOE:
|
||||||
if (!(gStatuses3[gBattlerTarget] & STATUS3_YAWN)
|
if (!(gStatuses3[gBattlerTarget] & STATUS3_YAWN)
|
||||||
&& !(gBattleMons[gBattlerTarget].status1 & STATUS1_ANY)
|
&& CanSleep(gBattlerTarget))
|
||||||
&& gBattleMons[gBattlerTarget].ability != ABILITY_VITAL_SPIRIT
|
|
||||||
&& gBattleMons[gBattlerTarget].ability != ABILITY_INSOMNIA
|
|
||||||
&& gBattleMons[gBattlerTarget].ability != ABILITY_COMATOSE
|
|
||||||
&& gBattleMons[gBattlerTarget].ability != ABILITY_PURIFYING_SALT
|
|
||||||
&& !IsFlowerVeilProtected(gBattlerTarget)
|
|
||||||
&& !(gBattleMons[gBattlerTarget].status2 & STATUS2_SUBSTITUTE)
|
|
||||||
&& !UproarWakeUpCheck(gActiveBattler))
|
|
||||||
{
|
{
|
||||||
gStatuses3[gBattlerTarget] |= STATUS3_YAWN_TURN(2);
|
gStatuses3[gBattlerTarget] |= STATUS3_YAWN_TURN(2);
|
||||||
BattleScriptPush(gBattlescriptCurrInstr + 1);
|
BattleScriptPush(gBattlescriptCurrInstr + 1);
|
||||||
|
@ -449,6 +485,23 @@ u16 SetMaxMoveEffect(u16 move)
|
||||||
effect++;
|
effect++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case MAX_EFFECT_PARALYZE_FOES:
|
||||||
|
case MAX_EFFECT_POISON_FOES:
|
||||||
|
case MAX_EFFECT_POISON_PARALYZE_FOES:
|
||||||
|
case MAX_EFFECT_EFFECT_SPORE_FOES:
|
||||||
|
BattleScriptPush(gBattlescriptCurrInstr + 1);
|
||||||
|
gBattlescriptCurrInstr = BattleScript_EffectStatus1Foes;
|
||||||
|
effect++;
|
||||||
|
break;
|
||||||
|
case MAX_EFFECT_CONFUSE_FOES_PAY_DAY:
|
||||||
|
case MAX_EFFECT_CONFUSE_FOES:
|
||||||
|
case MAX_EFFECT_INFATUATE_FOES:
|
||||||
|
case MAX_EFFECT_TORMENT_FOES:
|
||||||
|
case MAX_EFFECT_MEAN_LOOK:
|
||||||
|
BattleScriptPush(gBattlescriptCurrInstr + 1);
|
||||||
|
gBattlescriptCurrInstr = BattleScript_EffectStatus2Foes;
|
||||||
|
effect++;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
return effect;
|
return effect;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1893,6 +1893,11 @@ const u16 gStatusConditionsStringIds[] =
|
||||||
STRINGID_PKMNWASPOISONED, STRINGID_PKMNBADLYPOISONED, STRINGID_PKMNWASBURNED, STRINGID_PKMNWASPARALYZED, STRINGID_PKMNFELLASLEEP
|
STRINGID_PKMNWASPOISONED, STRINGID_PKMNBADLYPOISONED, STRINGID_PKMNWASBURNED, STRINGID_PKMNWASPARALYZED, STRINGID_PKMNFELLASLEEP
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const u16 gStatus2StringIds[] =
|
||||||
|
{
|
||||||
|
STRINGID_PKMNWASCONFUSED, STRINGID_PKMNFELLINLOVE, STRINGID_TARGETCANTESCAPENOW, STRINGID_PKMNSUBJECTEDTOTORMENT
|
||||||
|
};
|
||||||
|
|
||||||
const u16 gDamageNonTypesStartStringIds[] =
|
const u16 gDamageNonTypesStartStringIds[] =
|
||||||
{
|
{
|
||||||
STRINGID_TEAMTRAPPEDWITHVINES, STRINGID_TEAMCAUGHTINVORTEX, STRINGID_TEAMSURROUNDEDBYFIRE, STRINGID_TEAMSURROUNDEDBYROCKS
|
STRINGID_TEAMTRAPPEDWITHVINES, STRINGID_TEAMCAUGHTINVORTEX, STRINGID_TEAMSURROUNDEDBYFIRE, STRINGID_TEAMSURROUNDEDBYROCKS
|
||||||
|
|
|
@ -11210,6 +11210,120 @@ static void Cmd_various(void)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case VARIOUS_TRY_SET_STATUS1:
|
||||||
|
{
|
||||||
|
VARIOUS_ARGS(const u8 *failInstr);
|
||||||
|
u8 effect = 0;
|
||||||
|
u32 status1 = GetMaxMoveStatusEffect(gCurrentMove);
|
||||||
|
switch (status1)
|
||||||
|
{
|
||||||
|
case STATUS1_POISON:
|
||||||
|
if (CanBePoisoned(gBattlerAttacker, gBattlerTarget))
|
||||||
|
{
|
||||||
|
gBattleMons[gBattlerTarget].status1 |= STATUS1_POISON;
|
||||||
|
gBattleCommunication[MULTISTRING_CHOOSER] = 0;
|
||||||
|
effect++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case STATUS1_PARALYSIS:
|
||||||
|
if (CanBeParalyzed(gBattlerTarget))
|
||||||
|
{
|
||||||
|
gBattleMons[gBattlerTarget].status1 |= STATUS1_PARALYSIS;
|
||||||
|
gBattleCommunication[MULTISTRING_CHOOSER] = 3;
|
||||||
|
effect++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case STATUS1_SLEEP:
|
||||||
|
if (CanSleep(gBattlerTarget))
|
||||||
|
{
|
||||||
|
#if B_SLEEP_TURNS >= GEN_5
|
||||||
|
gBattleMons[gBattlerTarget].status1 |= STATUS1_SLEEP_TURN((Random() % 3) + 2);
|
||||||
|
#else
|
||||||
|
gBattleMons[gBattlerTarget].status1 |= STATUS1_SLEEP_TURN((Random() % 4) + 3);
|
||||||
|
#endif
|
||||||
|
gBattleCommunication[MULTISTRING_CHOOSER] = 4;
|
||||||
|
effect++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (effect)
|
||||||
|
{
|
||||||
|
gActiveBattler = gEffectBattler = gBattlerTarget;
|
||||||
|
BtlController_EmitSetMonData(BUFFER_A, REQUEST_STATUS_BATTLE, 0, sizeof(gBattleMons[gBattlerTarget].status1), &gBattleMons[gBattlerTarget].status1);
|
||||||
|
MarkBattlerForControllerExec(gActiveBattler);
|
||||||
|
gBattlescriptCurrInstr = cmd->nextInstr;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gBattlescriptCurrInstr = cmd->failInstr;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
case VARIOUS_TRY_SET_STATUS2:
|
||||||
|
{
|
||||||
|
VARIOUS_ARGS(const u8 *failInstr);
|
||||||
|
u8 effect = 0;
|
||||||
|
u32 status2 = GetMaxMoveStatusEffect(gCurrentMove);
|
||||||
|
switch (status2)
|
||||||
|
{
|
||||||
|
case STATUS2_CONFUSION:
|
||||||
|
if (CanBeConfused(gBattlerTarget))
|
||||||
|
{
|
||||||
|
gBattleMons[gBattlerTarget].status2 |= STATUS2_CONFUSION_TURN(((Random()) % 4) + 2);
|
||||||
|
gBattleCommunication[MULTISTRING_CHOOSER] = 0;
|
||||||
|
gBattleCommunication[MULTIUSE_STATE] = 1;
|
||||||
|
effect++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case STATUS2_INFATUATION:
|
||||||
|
{
|
||||||
|
u8 atkGender = GetGenderFromSpeciesAndPersonality(gBattleMons[gBattlerAttacker].species, gBattleMons[gBattlerAttacker].personality);
|
||||||
|
u8 defGender = GetGenderFromSpeciesAndPersonality(gBattleMons[gBattlerTarget].species, gBattleMons[gBattlerTarget].personality);
|
||||||
|
if (!(gBattleMons[gBattlerTarget].status2 & STATUS2_INFATUATION)
|
||||||
|
&& gBattleMons[gBattlerTarget].ability != ABILITY_OBLIVIOUS
|
||||||
|
&& !IsAbilityOnSide(gBattlerTarget, ABILITY_AROMA_VEIL)
|
||||||
|
&& atkGender != defGender
|
||||||
|
&& atkGender != MON_GENDERLESS
|
||||||
|
&& defGender != MON_GENDERLESS)
|
||||||
|
{
|
||||||
|
gBattleMons[gBattlerTarget].status2 |= STATUS2_INFATUATED_WITH(gBattlerAttacker);
|
||||||
|
gBattleCommunication[MULTISTRING_CHOOSER] = 1;
|
||||||
|
gBattleCommunication[MULTIUSE_STATE] = 2;
|
||||||
|
effect++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case STATUS2_ESCAPE_PREVENTION:
|
||||||
|
if (!(gBattleMons[gBattlerTarget].status2 & STATUS2_ESCAPE_PREVENTION))
|
||||||
|
{
|
||||||
|
gBattleMons[gBattlerTarget].status2 |= STATUS2_ESCAPE_PREVENTION;
|
||||||
|
gDisableStructs[gBattlerTarget].battlerPreventingEscape = gBattlerAttacker;
|
||||||
|
gBattleCommunication[MULTISTRING_CHOOSER] = 2;
|
||||||
|
effect++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case STATUS2_TORMENT:
|
||||||
|
if (!(gBattleMons[gBattlerTarget].status2 & STATUS2_TORMENT)
|
||||||
|
&& !IsAbilityOnSide(gBattlerTarget, ABILITY_AROMA_VEIL))
|
||||||
|
{
|
||||||
|
gBattleMons[gBattlerTarget].status2 |= STATUS2_TORMENT;
|
||||||
|
gDisableStructs[gBattlerTarget].tormentTimer = 4; // 3 turns excluding current turn
|
||||||
|
gBattleCommunication[MULTISTRING_CHOOSER] = 3;
|
||||||
|
effect++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (effect)
|
||||||
|
{
|
||||||
|
gEffectBattler = gBattlerTarget;
|
||||||
|
gBattlescriptCurrInstr = cmd->nextInstr;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gBattlescriptCurrInstr = cmd->failInstr;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
} // End of switch (cmd->id)
|
} // End of switch (cmd->id)
|
||||||
|
|
||||||
gBattlescriptCurrInstr = cmd->nextInstr;
|
gBattlescriptCurrInstr = cmd->nextInstr;
|
||||||
|
@ -14342,7 +14456,9 @@ static void Cmd_settorment(void)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
// TODO: Torment does not affect Dynamaxed Pokemon and prints a failure string.
|
||||||
gBattleMons[gBattlerTarget].status2 |= STATUS2_TORMENT;
|
gBattleMons[gBattlerTarget].status2 |= STATUS2_TORMENT;
|
||||||
|
gDisableStructs[gBattlerTarget].tormentTimer = 0xF; // permanent
|
||||||
gBattlescriptCurrInstr = cmd->nextInstr;
|
gBattlescriptCurrInstr = cmd->nextInstr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2675,6 +2675,7 @@ enum
|
||||||
ENDTURN_SLOW_START,
|
ENDTURN_SLOW_START,
|
||||||
ENDTURN_PLASMA_FISTS,
|
ENDTURN_PLASMA_FISTS,
|
||||||
ENDTURN_CUD_CHEW,
|
ENDTURN_CUD_CHEW,
|
||||||
|
ENDTURN_TORMENT,
|
||||||
ENDTURN_BATTLER_COUNT
|
ENDTURN_BATTLER_COUNT
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -3222,6 +3223,16 @@ u8 DoBattlerEndTurnEffects(void)
|
||||||
gDisableStructs[gActiveBattler].cudChew = TRUE;
|
gDisableStructs[gActiveBattler].cudChew = TRUE;
|
||||||
gBattleStruct->turnEffectsTracker++;
|
gBattleStruct->turnEffectsTracker++;
|
||||||
break;
|
break;
|
||||||
|
case ENDTURN_TORMENT:
|
||||||
|
if (gDisableStructs[gActiveBattler].tormentTimer <= 4
|
||||||
|
&& --gDisableStructs[gActiveBattler].tormentTimer == 0)
|
||||||
|
{
|
||||||
|
gBattleMons[gActiveBattler].status2 &= ~STATUS2_TORMENT;
|
||||||
|
BattleScriptExecute(BattleScript_TormentEnds);
|
||||||
|
effect++;
|
||||||
|
}
|
||||||
|
gBattleStruct->turnEffectsTracker++;
|
||||||
|
break;
|
||||||
case ENDTURN_BATTLER_COUNT: // done
|
case ENDTURN_BATTLER_COUNT: // done
|
||||||
gBattleStruct->turnEffectsTracker = 0;
|
gBattleStruct->turnEffectsTracker = 0;
|
||||||
gBattleStruct->turnEffectsBattlerId++;
|
gBattleStruct->turnEffectsBattlerId++;
|
||||||
|
|
Loading…
Reference in a new issue