From df447c48d3938187c343ad942b8951adc91415f5 Mon Sep 17 00:00:00 2001 From: Zimmermann Gyula Date: Tue, 19 Dec 2023 19:01:48 +0100 Subject: [PATCH 1/3] Realign battleanim array with battlemove array. --- data/battle_anim_scripts.s | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/data/battle_anim_scripts.s b/data/battle_anim_scripts.s index ce841e4a24..e101540851 100644 --- a/data/battle_anim_scripts.s +++ b/data/battle_anim_scripts.s @@ -860,6 +860,21 @@ gBattleAnims_Moves:: .4byte Move_MATCHA_GOTCHA .4byte Move_SYRUP_BOMB .4byte Move_IVY_CUDGEL + .4byte Move_833 + .4byte Move_834 + .4byte Move_835 + .4byte Move_836 + .4byte Move_837 + .4byte Move_838 + .4byte Move_839 + .4byte Move_840 + .4byte Move_841 + .4byte Move_842 + .4byte Move_843 + .4byte Move_844 + .4byte Move_845 + .4byte Move_846 + .4byte Move_847 @@@@ Z MOVES .4byte Move_BREAKNECK_BLITZ .4byte Move_ALL_OUT_PUMMELING @@ -16963,6 +16978,21 @@ Move_IVY_CUDGEL:: Move_NONE: Move_MIRROR_MOVE: Move_POUND: +Move_833: +Move_834: +Move_835: +Move_836: +Move_837: +Move_838: +Move_839: +Move_840: +Move_841: +Move_842: +Move_843: +Move_844: +Move_845: +Move_846: +Move_847: loadspritegfx ANIM_TAG_IMPACT monbg ANIM_TARGET setalpha 12, 8 From 069769710bf740864961b0dacccbb7b7824582dd Mon Sep 17 00:00:00 2001 From: Alex <93446519+AlexOn1ine@users.noreply.github.com> Date: Wed, 20 Dec 2023 11:24:12 +0100 Subject: [PATCH 2/3] Fixes Item Metronome damage (#3767) Co-authored-by: Bassoonian --- include/constants/battle_script_commands.h | 5 +++-- src/battle_script_commands.c | 15 +++++++++------ test/battle/hold_effect/metronome.c | 2 -- 3 files changed, 12 insertions(+), 10 deletions(-) diff --git a/include/constants/battle_script_commands.h b/include/constants/battle_script_commands.h index 7e95ea785b..4899d37036 100644 --- a/include/constants/battle_script_commands.h +++ b/include/constants/battle_script_commands.h @@ -317,8 +317,9 @@ #define MOVEEND_EMERGENCY_EXIT 33 #define MOVEEND_SYMBIOSIS 34 #define MOVEEND_OPPORTUNIST 35 // Occurs after other stat change items/abilities to try and copy the boosts -#define MOVEEND_CLEAR_BITS 36 -#define MOVEEND_COUNT 37 +#define MOVEEND_SAME_MOVE_TURNS 36 +#define MOVEEND_CLEAR_BITS 37 +#define MOVEEND_COUNT 38 // switch cases #define B_SWITCH_NORMAL 0 diff --git a/src/battle_script_commands.c b/src/battle_script_commands.c index a250c910c9..e2705433ca 100644 --- a/src/battle_script_commands.c +++ b/src/battle_script_commands.c @@ -1858,13 +1858,9 @@ static void Cmd_ppreduce(void) if (!(gHitMarker & (HITMARKER_NO_PPDEDUCT | HITMARKER_NO_ATTACKSTRING)) && gBattleMons[gBattlerAttacker].pp[gCurrMovePos]) { gProtectStructs[gBattlerAttacker].notFirstStrike = TRUE; + // For item Metronome, echoed voice - if (gCurrentMove == gLastResultingMoves[gBattlerAttacker] - && !(gMoveResultFlags & MOVE_RESULT_NO_EFFECT) - && !WasUnableToUseMove(gBattlerAttacker) - && gSpecialStatuses[gBattlerAttacker].parentalBondState != PARENTAL_BOND_1ST_HIT) // Don't increment counter on first hit - gBattleStruct->sameMoveTurns[gBattlerAttacker]++; - else + if (gCurrentMove != gLastResultingMoves[gBattlerAttacker] || WasUnableToUseMove(gBattlerAttacker)) gBattleStruct->sameMoveTurns[gBattlerAttacker] = 0; if (gBattleMons[gBattlerAttacker].pp[gCurrMovePos] > ppToDeduct) @@ -6079,6 +6075,13 @@ static void Cmd_moveend(void) } gBattleScripting.moveendState++; break; + case MOVEEND_SAME_MOVE_TURNS: + if (gCurrentMove != gLastResultingMoves[gBattlerAttacker] || gMoveResultFlags & MOVE_RESULT_NO_EFFECT) + gBattleStruct->sameMoveTurns[gBattlerAttacker] = 0; + else if (gCurrentMove == gLastResultingMoves[gBattlerAttacker] && gSpecialStatuses[gBattlerAttacker].parentalBondState != PARENTAL_BOND_1ST_HIT) + gBattleStruct->sameMoveTurns[gBattlerAttacker]++; + gBattleScripting.moveendState++; + break; case MOVEEND_CLEAR_BITS: // Clear/Set bits for things like using a move for all targets and all hits. if (gSpecialStatuses[gBattlerAttacker].instructedChosenTarget) *(gBattleStruct->moveTarget + gBattlerAttacker) = gSpecialStatuses[gBattlerAttacker].instructedChosenTarget & 0x3; diff --git a/test/battle/hold_effect/metronome.c b/test/battle/hold_effect/metronome.c index 63a0bb3eae..5b089703e9 100644 --- a/test/battle/hold_effect/metronome.c +++ b/test/battle/hold_effect/metronome.c @@ -67,7 +67,6 @@ SINGLE_BATTLE_TEST("Metronome Item's boost is reset if the attacker uses a diffe SINGLE_BATTLE_TEST("Metronome Item's boost is reset if the move fails") { s16 damage[2]; - KNOWN_FAILING; //https://github.com/rh-hideout/pokeemerald-expansion/issues/3251 GIVEN { PLAYER(SPECIES_WOBBUFFET) { Item(ITEM_METRONOME); } OPPONENT(SPECIES_WOBBUFFET); @@ -110,7 +109,6 @@ SINGLE_BATTLE_TEST("Metronome Item counts charging turn of moves for its attacki { u32 item; - KNOWN_FAILING; // https://github.com/rh-hideout/pokeemerald-expansion/issues/3250 PARAMETRIZE {item = ITEM_NONE; } PARAMETRIZE {item = ITEM_METRONOME; } GIVEN { From 3b7782ed4910532cd5a9122451d763352db01517 Mon Sep 17 00:00:00 2001 From: DizzyEggg Date: Wed, 20 Dec 2023 11:48:52 +0100 Subject: [PATCH 3/3] Clear BattleScripting struct at the battle start (#3776) --- src/battle_main.c | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/src/battle_main.c b/src/battle_main.c index 0f708d41ee..a6eb17c130 100644 --- a/src/battle_main.c +++ b/src/battle_main.c @@ -2961,6 +2961,10 @@ static void BattleStartClearSetData(void) memset(&gSideTimers, 0, sizeof(gSideTimers)); memset(&gWishFutureKnock, 0, sizeof(gWishFutureKnock)); memset(&gBattleResults, 0, sizeof(gBattleResults)); + memset(&gBattleScripting, 0, sizeof(gBattleScripting)); + + gBattleScripting.battleStyle = gSaveBlock2Ptr->optionsBattleStyle; + gBattleScripting.expOnCatch = (B_EXP_CATCH >= GEN_6); for (i = 0; i < MAX_BATTLERS_COUNT; i++) { @@ -2997,7 +3001,6 @@ static void BattleStartClearSetData(void) gBattlerAttacker = 0; gBattlerTarget = 0; gEffectBattler = 0; - gBattleScripting.battler = 0; gBattlerAbility = 0; gBattleWeather = 0; gHitMarker = 0; @@ -3012,12 +3015,7 @@ static void BattleStartClearSetData(void) gHitMarker |= HITMARKER_NO_ANIMATIONS; } - gBattleScripting.battleStyle = gSaveBlock2Ptr->optionsBattleStyle; - gBattleScripting.expOnCatch = (B_EXP_CATCH >= GEN_6); - gBattleScripting.monCaught = FALSE; - gMultiHitCounter = 0; - gBattleScripting.savedDmg = 0; gBattleOutcome = 0; gBattleControllerExecFlags = 0; gPaydayMoney = 0; @@ -3030,8 +3028,6 @@ static void BattleStartClearSetData(void) gPauseCounterBattle = 0; gBattleMoveDamage = 0; gIntroSlideFlags = 0; - gBattleScripting.animTurn = 0; - gBattleScripting.animTargetsHit = 0; gLeveledUpInBattle = 0; gAbsentBattlerFlags = 0; gBattleStruct->runTries = 0;