Remove and replace MOVE_EFFECT_SP_ATK_TWO_DOWN (#4557)

This commit is contained in:
sneed 2024-05-12 16:07:43 +03:00 committed by GitHub
parent be37820bd9
commit a8bb82778a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
11 changed files with 32 additions and 56 deletions

View file

@ -6997,17 +6997,6 @@ BattleScript_OneHitKOMsg::
waitmessage B_WAIT_TIME_LONG waitmessage B_WAIT_TIME_LONG
return return
BattleScript_SAtkDown2::
setbyte sSTAT_ANIM_PLAYED, FALSE
playstatchangeanimation BS_ATTACKER, BIT_SPATK, STAT_CHANGE_CANT_PREVENT | STAT_CHANGE_NEGATIVE | STAT_CHANGE_BY_TWO
setstatchanger STAT_SPATK, 2, TRUE
statbuffchange MOVE_EFFECT_AFFECTS_USER | MOVE_EFFECT_CERTAIN | STAT_CHANGE_ALLOW_PTR, BattleScript_SAtkDown2End
jumpifbyte CMP_EQUAL, cMULTISTRING_CHOOSER, B_MSG_STAT_WONT_DECREASE, BattleScript_SAtkDown2End
printfromtable gStatDownStringIds
waitmessage B_WAIT_TIME_LONG
BattleScript_SAtkDown2End::
return
BattleScript_MoveEffectClearSmog:: BattleScript_MoveEffectClearSmog::
printstring STRINGID_RESETSTARGETSSTATLEVELS printstring STRINGID_RESETSTARGETSSTATLEVELS
waitmessage B_WAIT_TIME_LONG waitmessage B_WAIT_TIME_LONG

View file

@ -113,7 +113,6 @@ extern const u8 BattleScript_MagicCoatBouncePrankster[];
extern const u8 BattleScript_SnatchedMove[]; extern const u8 BattleScript_SnatchedMove[];
extern const u8 BattleScript_EnduredMsg[]; extern const u8 BattleScript_EnduredMsg[];
extern const u8 BattleScript_OneHitKOMsg[]; extern const u8 BattleScript_OneHitKOMsg[];
extern const u8 BattleScript_SAtkDown2[];
extern const u8 BattleScript_FocusPunchSetUp[]; extern const u8 BattleScript_FocusPunchSetUp[];
extern const u8 BattleScript_MoveUsedIsAsleep[]; extern const u8 BattleScript_MoveUsedIsAsleep[];
extern const u8 BattleScript_MoveUsedWokeUp[]; extern const u8 BattleScript_MoveUsedWokeUp[];

View file

@ -380,31 +380,30 @@
#define MOVE_EFFECT_KNOCK_OFF 55 #define MOVE_EFFECT_KNOCK_OFF 55
#define MOVE_EFFECT_DEF_SPDEF_DOWN 56 #define MOVE_EFFECT_DEF_SPDEF_DOWN 56
#define MOVE_EFFECT_CLEAR_SMOG 57 #define MOVE_EFFECT_CLEAR_SMOG 57
#define MOVE_EFFECT_SP_ATK_TWO_DOWN 58 #define MOVE_EFFECT_SMACK_DOWN 58
#define MOVE_EFFECT_SMACK_DOWN 59 #define MOVE_EFFECT_FLAME_BURST 59
#define MOVE_EFFECT_FLAME_BURST 60 #define MOVE_EFFECT_FEINT 60
#define MOVE_EFFECT_FEINT 61 #define MOVE_EFFECT_SPECTRAL_THIEF 61
#define MOVE_EFFECT_SPECTRAL_THIEF 62 #define MOVE_EFFECT_V_CREATE 62
#define MOVE_EFFECT_V_CREATE 63 #define MOVE_EFFECT_HAPPY_HOUR 63
#define MOVE_EFFECT_HAPPY_HOUR 64 #define MOVE_EFFECT_CORE_ENFORCER 64
#define MOVE_EFFECT_CORE_ENFORCER 65 #define MOVE_EFFECT_THROAT_CHOP 65
#define MOVE_EFFECT_THROAT_CHOP 66 #define MOVE_EFFECT_INCINERATE 66
#define MOVE_EFFECT_INCINERATE 67 #define MOVE_EFFECT_BUG_BITE 67
#define MOVE_EFFECT_BUG_BITE 68 #define MOVE_EFFECT_RECOIL_HP_25 68
#define MOVE_EFFECT_RECOIL_HP_25 69 #define MOVE_EFFECT_TRAP_BOTH 69
#define MOVE_EFFECT_TRAP_BOTH 70 #define MOVE_EFFECT_ROUND 70
#define MOVE_EFFECT_ROUND 71 #define MOVE_EFFECT_STOCKPILE_WORE_OFF 71
#define MOVE_EFFECT_STOCKPILE_WORE_OFF 72 #define MOVE_EFFECT_DIRE_CLAW 72
#define MOVE_EFFECT_DIRE_CLAW 73 #define MOVE_EFFECT_STEALTH_ROCK 73
#define MOVE_EFFECT_STEALTH_ROCK 74 #define MOVE_EFFECT_SPIKES 74
#define MOVE_EFFECT_SPIKES 75 #define MOVE_EFFECT_SYRUP_BOMB 75
#define MOVE_EFFECT_SYRUP_BOMB 76 #define MOVE_EFFECT_FLORAL_HEALING 76
#define MOVE_EFFECT_FLORAL_HEALING 77 #define MOVE_EFFECT_SECRET_POWER 77
#define MOVE_EFFECT_SECRET_POWER 78 #define MOVE_EFFECT_PSYCHIC_NOISE 78
#define MOVE_EFFECT_PSYCHIC_NOISE 79 #define MOVE_EFFECT_TERA_BLAST 79
#define MOVE_EFFECT_TERA_BLAST 80
#define NUM_MOVE_EFFECTS 81 #define NUM_MOVE_EFFECTS 80
#define MOVE_EFFECT_AFFECTS_USER 0x2000 #define MOVE_EFFECT_AFFECTS_USER 0x2000
#define MOVE_EFFECT_CERTAIN 0x4000 #define MOVE_EFFECT_CERTAIN 0x4000

View file

@ -4496,9 +4496,6 @@ static u32 AI_CalcMoveEffectScore(u32 battlerAtk, u32 battlerDef, u32 move)
IncreaseStatUpScoreContrary(battlerAtk, battlerDef, STAT_CHANGE_ATK, &score); IncreaseStatUpScoreContrary(battlerAtk, battlerDef, STAT_CHANGE_ATK, &score);
IncreaseStatUpScoreContrary(battlerAtk, battlerDef, STAT_CHANGE_DEF, &score); IncreaseStatUpScoreContrary(battlerAtk, battlerDef, STAT_CHANGE_DEF, &score);
break; break;
case MOVE_EFFECT_SP_ATK_TWO_DOWN:
IncreaseStatUpScoreContrary(battlerAtk, battlerDef, STAT_CHANGE_SPATK_2, &score);
break;
case MOVE_EFFECT_V_CREATE: case MOVE_EFFECT_V_CREATE:
IncreaseStatUpScoreContrary(battlerAtk, battlerDef, STAT_CHANGE_DEF, &score); IncreaseStatUpScoreContrary(battlerAtk, battlerDef, STAT_CHANGE_DEF, &score);
IncreaseStatUpScoreContrary(battlerAtk, battlerDef, STAT_CHANGE_SPEED, &score); IncreaseStatUpScoreContrary(battlerAtk, battlerDef, STAT_CHANGE_SPEED, &score);

View file

@ -778,7 +778,6 @@ static bool32 AI_IsMoveEffectInMinus(u32 battlerAtk, u32 battlerDef, u32 move, s
case MOVE_EFFECT_SP_DEF_MINUS_2: case MOVE_EFFECT_SP_DEF_MINUS_2:
case MOVE_EFFECT_EVS_MINUS_2: case MOVE_EFFECT_EVS_MINUS_2:
case MOVE_EFFECT_ACC_MINUS_2: case MOVE_EFFECT_ACC_MINUS_2:
case MOVE_EFFECT_SP_ATK_TWO_DOWN:
case MOVE_EFFECT_V_CREATE: case MOVE_EFFECT_V_CREATE:
case MOVE_EFFECT_ATK_DEF_DOWN: case MOVE_EFFECT_ATK_DEF_DOWN:
case MOVE_EFFECT_DEF_SPDEF_DOWN: case MOVE_EFFECT_DEF_SPDEF_DOWN:

View file

@ -3500,13 +3500,6 @@ void SetMoveEffect(bool32 primary, bool32 certain)
gBattleMons[gEffectBattler].status2 |= STATUS2_LOCK_CONFUSE_TURN(RandomUniform(RNG_RAMPAGE_TURNS, 2, 3)); gBattleMons[gEffectBattler].status2 |= STATUS2_LOCK_CONFUSE_TURN(RandomUniform(RNG_RAMPAGE_TURNS, 2, 3));
} }
break; break;
case MOVE_EFFECT_SP_ATK_TWO_DOWN: // Overheat
if (!NoAliveMonsForEitherParty())
{
BattleScriptPush(gBattlescriptCurrInstr + 1);
gBattlescriptCurrInstr = BattleScript_SAtkDown2;
}
break;
case MOVE_EFFECT_CLEAR_SMOG: case MOVE_EFFECT_CLEAR_SMOG:
for (i = 0; i < NUM_BATTLE_STATS; i++) for (i = 0; i < NUM_BATTLE_STATS; i++)
{ {

View file

@ -944,7 +944,7 @@ static void AddMovePoints(u8 caseId, u16 arg1, u8 arg2, u8 arg3)
baseFromEffect++; // Recoil moves baseFromEffect++; // Recoil moves
if (MoveHasAdditionalEffect(arg2, MOVE_EFFECT_RAPID_SPIN)) if (MoveHasAdditionalEffect(arg2, MOVE_EFFECT_RAPID_SPIN))
baseFromEffect++; baseFromEffect++;
if (MoveHasAdditionalEffect(arg2, MOVE_EFFECT_SP_ATK_TWO_DOWN) || MoveHasAdditionalEffect(arg2, MOVE_EFFECT_ATK_DEF_DOWN)) if (MoveHasAdditionalEffect(arg2, MOVE_EFFECT_SP_ATK_MINUS_2) || MoveHasAdditionalEffect(arg2, MOVE_EFFECT_ATK_DEF_DOWN))
baseFromEffect += 2; // Overheat, Superpower, etc. baseFromEffect += 2; // Overheat, Superpower, etc.
if (MoveHasAdditionalEffect(arg2, MOVE_EFFECT_STEAL_ITEM)) if (MoveHasAdditionalEffect(arg2, MOVE_EFFECT_STEAL_ITEM))
baseFromEffect += 3; baseFromEffect += 3;

View file

@ -7671,7 +7671,7 @@ const struct MoveInfo gMovesInfo[MOVES_COUNT_DYNAMAX] =
.category = DAMAGE_CATEGORY_SPECIAL, .category = DAMAGE_CATEGORY_SPECIAL,
.makesContact = B_UPDATED_MOVE_DATA < GEN_4, .makesContact = B_UPDATED_MOVE_DATA < GEN_4,
.additionalEffects = ADDITIONAL_EFFECTS({ .additionalEffects = ADDITIONAL_EFFECTS({
.moveEffect = MOVE_EFFECT_SP_ATK_TWO_DOWN, .moveEffect = MOVE_EFFECT_SP_ATK_MINUS_2,
.self = TRUE, .self = TRUE,
}), }),
.contestEffect = CONTEST_EFFECT_USER_MORE_EASILY_STARTLED, .contestEffect = CONTEST_EFFECT_USER_MORE_EASILY_STARTLED,
@ -8589,7 +8589,7 @@ const struct MoveInfo gMovesInfo[MOVES_COUNT_DYNAMAX] =
.priority = 0, .priority = 0,
.category = DAMAGE_CATEGORY_SPECIAL, .category = DAMAGE_CATEGORY_SPECIAL,
.additionalEffects = ADDITIONAL_EFFECTS({ .additionalEffects = ADDITIONAL_EFFECTS({
.moveEffect = MOVE_EFFECT_SP_ATK_TWO_DOWN, .moveEffect = MOVE_EFFECT_SP_ATK_MINUS_2,
.self = TRUE, .self = TRUE,
}), }),
.contestEffect = CONTEST_EFFECT_USER_MORE_EASILY_STARTLED, .contestEffect = CONTEST_EFFECT_USER_MORE_EASILY_STARTLED,
@ -10456,7 +10456,7 @@ const struct MoveInfo gMovesInfo[MOVES_COUNT_DYNAMAX] =
.priority = 0, .priority = 0,
.category = DAMAGE_CATEGORY_SPECIAL, .category = DAMAGE_CATEGORY_SPECIAL,
.additionalEffects = ADDITIONAL_EFFECTS({ .additionalEffects = ADDITIONAL_EFFECTS({
.moveEffect = MOVE_EFFECT_SP_ATK_TWO_DOWN, .moveEffect = MOVE_EFFECT_SP_ATK_MINUS_2,
.self = TRUE, .self = TRUE,
}), }),
.contestEffect = CONTEST_EFFECT_USER_MORE_EASILY_STARTLED, .contestEffect = CONTEST_EFFECT_USER_MORE_EASILY_STARTLED,
@ -10526,7 +10526,7 @@ const struct MoveInfo gMovesInfo[MOVES_COUNT_DYNAMAX] =
.priority = 0, .priority = 0,
.category = DAMAGE_CATEGORY_SPECIAL, .category = DAMAGE_CATEGORY_SPECIAL,
.additionalEffects = ADDITIONAL_EFFECTS({ .additionalEffects = ADDITIONAL_EFFECTS({
.moveEffect = MOVE_EFFECT_SP_ATK_TWO_DOWN, .moveEffect = MOVE_EFFECT_SP_ATK_MINUS_2,
.self = TRUE, .self = TRUE,
}), }),
.contestEffect = CONTEST_EFFECT_USER_MORE_EASILY_STARTLED, .contestEffect = CONTEST_EFFECT_USER_MORE_EASILY_STARTLED,
@ -15741,7 +15741,7 @@ const struct MoveInfo gMovesInfo[MOVES_COUNT_DYNAMAX] =
.category = DAMAGE_CATEGORY_SPECIAL, .category = DAMAGE_CATEGORY_SPECIAL,
.metronomeBanned = TRUE, .metronomeBanned = TRUE,
.additionalEffects = ADDITIONAL_EFFECTS({ .additionalEffects = ADDITIONAL_EFFECTS({
.moveEffect = MOVE_EFFECT_SP_ATK_TWO_DOWN, .moveEffect = MOVE_EFFECT_SP_ATK_MINUS_2,
.self = TRUE, .self = TRUE,
}), }),
.contestEffect = CONTEST_EFFECT_USER_MORE_EASILY_STARTLED, .contestEffect = CONTEST_EFFECT_USER_MORE_EASILY_STARTLED,

View file

@ -82,7 +82,7 @@ SINGLE_BATTLE_TEST("Contrary raises stats after using a move which would normall
PARAMETRIZE { ability = ABILITY_CONTRARY; } PARAMETRIZE { ability = ABILITY_CONTRARY; }
PARAMETRIZE { ability = ABILITY_TANGLED_FEET; } PARAMETRIZE { ability = ABILITY_TANGLED_FEET; }
GIVEN { GIVEN {
ASSUME(MoveHasAdditionalEffectSelf(MOVE_OVERHEAT, MOVE_EFFECT_SP_ATK_TWO_DOWN) == TRUE); ASSUME(MoveHasAdditionalEffectSelf(MOVE_OVERHEAT, MOVE_EFFECT_SP_ATK_MINUS_2) == TRUE);
ASSUME(gMovesInfo[MOVE_OVERHEAT].category == DAMAGE_CATEGORY_SPECIAL); ASSUME(gMovesInfo[MOVE_OVERHEAT].category == DAMAGE_CATEGORY_SPECIAL);
PLAYER(SPECIES_WOBBUFFET); PLAYER(SPECIES_WOBBUFFET);
OPPONENT(SPECIES_SPINDA) { Ability(ability); } OPPONENT(SPECIES_SPINDA) { Ability(ability); }

View file

@ -95,7 +95,7 @@ SINGLE_BATTLE_TEST("Shield Dust does not block self-targeting effects, primary o
GIVEN { GIVEN {
ASSUME(MoveHasAdditionalEffectSelf(MOVE_POWER_UP_PUNCH, MOVE_EFFECT_ATK_PLUS_1) == TRUE); ASSUME(MoveHasAdditionalEffectSelf(MOVE_POWER_UP_PUNCH, MOVE_EFFECT_ATK_PLUS_1) == TRUE);
ASSUME(MoveHasAdditionalEffectSelf(MOVE_RAPID_SPIN, MOVE_EFFECT_RAPID_SPIN) == TRUE); ASSUME(MoveHasAdditionalEffectSelf(MOVE_RAPID_SPIN, MOVE_EFFECT_RAPID_SPIN) == TRUE);
ASSUME(MoveHasAdditionalEffectSelf(MOVE_LEAF_STORM, MOVE_EFFECT_SP_ATK_TWO_DOWN) == TRUE); ASSUME(MoveHasAdditionalEffectSelf(MOVE_LEAF_STORM, MOVE_EFFECT_SP_ATK_MINUS_2) == TRUE);
ASSUME(MoveHasAdditionalEffectSelf(MOVE_METEOR_ASSAULT, MOVE_EFFECT_RECHARGE) == TRUE); ASSUME(MoveHasAdditionalEffectSelf(MOVE_METEOR_ASSAULT, MOVE_EFFECT_RECHARGE) == TRUE);
PLAYER(SPECIES_WOBBUFFET); PLAYER(SPECIES_WOBBUFFET);
OPPONENT(SPECIES_VIVILLON) { Ability(ABILITY_SHIELD_DUST); } OPPONENT(SPECIES_VIVILLON) { Ability(ABILITY_SHIELD_DUST); }

View file

@ -3,7 +3,7 @@
ASSUMPTIONS ASSUMPTIONS
{ {
ASSUME(MoveHasAdditionalEffectSelf(MOVE_OVERHEAT, MOVE_EFFECT_SP_ATK_TWO_DOWN)); ASSUME(MoveHasAdditionalEffectSelf(MOVE_OVERHEAT, MOVE_EFFECT_SP_ATK_MINUS_2));
} }
SINGLE_BATTLE_TEST("Overheat drops Sp. Atk by 2 stages - singles") SINGLE_BATTLE_TEST("Overheat drops Sp. Atk by 2 stages - singles")