Revert the broken CheckTypeMatchup bugfix simplification from 5728d01417

This commit is contained in:
Rangi 2020-03-21 14:03:38 -04:00
parent 6a6ba10315
commit 7558b98a81
1 changed files with 5 additions and 3 deletions

View File

@ -901,8 +901,12 @@ This bug existed for all battles in Gold and Silver, and was only fixed for sing
ld hl, wEnemyMonType1 ld hl, wEnemyMonType1
ldh a, [hBattleTurn] ldh a, [hBattleTurn]
and a and a
jr z, CheckTypeMatchup - jr z, CheckTypeMatchup
+ jr z, .get_type
ld hl, wBattleMonType1 ld hl, wBattleMonType1
+.get_type
+ ld a, BATTLE_VARS_MOVE_TYPE
+ call GetBattleVar ; preserves hl, de, and bc
CheckTypeMatchup: CheckTypeMatchup:
-; There is an incorrect assumption about this function made in the AI related code: when -; There is an incorrect assumption about this function made in the AI related code: when
-; the AI calls CheckTypeMatchup (not BattleCheckTypeMatchup), it assumes that placing the -; the AI calls CheckTypeMatchup (not BattleCheckTypeMatchup), it assumes that placing the
@ -910,8 +914,6 @@ This bug existed for all battles in Gold and Silver, and was only fixed for sing
-; this assumption is incorrect. A simple fix would be to load the move type for the -; this assumption is incorrect. A simple fix would be to load the move type for the
-; current move into a in BattleCheckTypeMatchup, before falling through, which is -; current move into a in BattleCheckTypeMatchup, before falling through, which is
-; consistent with how the rest of the code assumes this code works like. -; consistent with how the rest of the code assumes this code works like.
+ ld a, BATTLE_VARS_MOVE_TYPE
+ call GetBattleVar ; preserves hl, de, and bc
push hl push hl
push de push de
push bc push bc