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:
AgustinGDLV 2023-02-27 21:26:03 -08:00
parent 0908129c84
commit da24b717e4
10 changed files with 269 additions and 16 deletions

View file

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

View file

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

View file

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

View file

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

View file

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

View file

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

View file

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

View file

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

View file

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

View file

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