mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2025-01-16 16:42:10 +01:00
Merge pull request #816 from jiangzhengwenjz/ptch-3
get rid of goto in battle_script_commands
This commit is contained in:
commit
886f043025
@ -1681,29 +1681,22 @@ static void atk07_adjustnormaldamage(void)
|
|||||||
RecordItemEffectBattle(gBattlerTarget, holdEffect);
|
RecordItemEffectBattle(gBattlerTarget, holdEffect);
|
||||||
gSpecialStatuses[gBattlerTarget].focusBanded = 1;
|
gSpecialStatuses[gBattlerTarget].focusBanded = 1;
|
||||||
}
|
}
|
||||||
if (gBattleMons[gBattlerTarget].status2 & STATUS2_SUBSTITUTE)
|
if (!(gBattleMons[gBattlerTarget].status2 & STATUS2_SUBSTITUTE)
|
||||||
goto END;
|
&& (gBattleMoves[gCurrentMove].effect == EFFECT_FALSE_SWIPE || gProtectStructs[gBattlerTarget].endured || gSpecialStatuses[gBattlerTarget].focusBanded)
|
||||||
if (gBattleMoves[gCurrentMove].effect != EFFECT_FALSE_SWIPE && !gProtectStructs[gBattlerTarget].endured
|
&& gBattleMons[gBattlerTarget].hp <= gBattleMoveDamage)
|
||||||
&& !gSpecialStatuses[gBattlerTarget].focusBanded)
|
|
||||||
goto END;
|
|
||||||
|
|
||||||
if (gBattleMons[gBattlerTarget].hp > gBattleMoveDamage)
|
|
||||||
goto END;
|
|
||||||
|
|
||||||
gBattleMoveDamage = gBattleMons[gBattlerTarget].hp - 1;
|
|
||||||
|
|
||||||
if (gProtectStructs[gBattlerTarget].endured)
|
|
||||||
{
|
{
|
||||||
gMoveResultFlags |= MOVE_RESULT_FOE_ENDURED;
|
gBattleMoveDamage = gBattleMons[gBattlerTarget].hp - 1;
|
||||||
|
if (gProtectStructs[gBattlerTarget].endured)
|
||||||
|
{
|
||||||
|
gMoveResultFlags |= MOVE_RESULT_FOE_ENDURED;
|
||||||
|
}
|
||||||
|
else if (gSpecialStatuses[gBattlerTarget].focusBanded)
|
||||||
|
{
|
||||||
|
gMoveResultFlags |= MOVE_RESULT_FOE_HUNG_ON;
|
||||||
|
gLastUsedItem = gBattleMons[gBattlerTarget].item;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (gSpecialStatuses[gBattlerTarget].focusBanded)
|
gBattlescriptCurrInstr++;
|
||||||
{
|
|
||||||
gMoveResultFlags |= MOVE_RESULT_FOE_HUNG_ON;
|
|
||||||
gLastUsedItem = gBattleMons[gBattlerTarget].item;
|
|
||||||
}
|
|
||||||
|
|
||||||
END:
|
|
||||||
gBattlescriptCurrInstr++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void atk08_adjustnormaldamage2(void) // The same as 0x7 except it doesn't check for false swipe move effect.
|
static void atk08_adjustnormaldamage2(void) // The same as 0x7 except it doesn't check for false swipe move effect.
|
||||||
@ -1730,27 +1723,22 @@ static void atk08_adjustnormaldamage2(void) // The same as 0x7 except it doesn't
|
|||||||
RecordItemEffectBattle(gBattlerTarget, holdEffect);
|
RecordItemEffectBattle(gBattlerTarget, holdEffect);
|
||||||
gSpecialStatuses[gBattlerTarget].focusBanded = 1;
|
gSpecialStatuses[gBattlerTarget].focusBanded = 1;
|
||||||
}
|
}
|
||||||
if (gBattleMons[gBattlerTarget].status2 & STATUS2_SUBSTITUTE)
|
if (!(gBattleMons[gBattlerTarget].status2 & STATUS2_SUBSTITUTE)
|
||||||
goto END;
|
&& (gProtectStructs[gBattlerTarget].endured || gSpecialStatuses[gBattlerTarget].focusBanded)
|
||||||
if (!gProtectStructs[gBattlerTarget].endured && !gSpecialStatuses[gBattlerTarget].focusBanded)
|
&& gBattleMons[gBattlerTarget].hp <= gBattleMoveDamage)
|
||||||
goto END;
|
|
||||||
if (gBattleMons[gBattlerTarget].hp > gBattleMoveDamage)
|
|
||||||
goto END;
|
|
||||||
|
|
||||||
gBattleMoveDamage = gBattleMons[gBattlerTarget].hp - 1;
|
|
||||||
|
|
||||||
if (gProtectStructs[gBattlerTarget].endured)
|
|
||||||
{
|
{
|
||||||
gMoveResultFlags |= MOVE_RESULT_FOE_ENDURED;
|
gBattleMoveDamage = gBattleMons[gBattlerTarget].hp - 1;
|
||||||
|
if (gProtectStructs[gBattlerTarget].endured)
|
||||||
|
{
|
||||||
|
gMoveResultFlags |= MOVE_RESULT_FOE_ENDURED;
|
||||||
|
}
|
||||||
|
else if (gSpecialStatuses[gBattlerTarget].focusBanded)
|
||||||
|
{
|
||||||
|
gMoveResultFlags |= MOVE_RESULT_FOE_HUNG_ON;
|
||||||
|
gLastUsedItem = gBattleMons[gBattlerTarget].item;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (gSpecialStatuses[gBattlerTarget].focusBanded)
|
gBattlescriptCurrInstr++;
|
||||||
{
|
|
||||||
gMoveResultFlags |= MOVE_RESULT_FOE_HUNG_ON;
|
|
||||||
gLastUsedItem = gBattleMons[gBattlerTarget].item;
|
|
||||||
}
|
|
||||||
|
|
||||||
END:
|
|
||||||
gBattlescriptCurrInstr++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void atk09_attackanimation(void)
|
static void atk09_attackanimation(void)
|
||||||
@ -4564,27 +4552,26 @@ static void atk49_moveend(void)
|
|||||||
gBattleScripting.atk49_state++;
|
gBattleScripting.atk49_state++;
|
||||||
break;
|
break;
|
||||||
case ATK49_CHOICE_MOVE: // update choice band move
|
case ATK49_CHOICE_MOVE: // update choice band move
|
||||||
if (!(gHitMarker & HITMARKER_OBEYS) || holdEffectAtk != HOLD_EFFECT_CHOICE_BAND
|
if (gHitMarker & HITMARKER_OBEYS
|
||||||
|| gChosenMove == MOVE_STRUGGLE || (*choicedMoveAtk != 0 && *choicedMoveAtk != 0xFFFF))
|
&& holdEffectAtk == HOLD_EFFECT_CHOICE_BAND
|
||||||
goto LOOP;
|
&& gChosenMove != MOVE_STRUGGLE
|
||||||
if (gChosenMove == MOVE_BATON_PASS && !(gMoveResultFlags & MOVE_RESULT_FAILED))
|
&& (*choicedMoveAtk == 0 || *choicedMoveAtk == 0xFFFF))
|
||||||
{
|
{
|
||||||
gBattleScripting.atk49_state++;
|
if (gChosenMove == MOVE_BATON_PASS && !(gMoveResultFlags & MOVE_RESULT_FAILED))
|
||||||
break;
|
|
||||||
}
|
|
||||||
*choicedMoveAtk = gChosenMove;
|
|
||||||
LOOP:
|
|
||||||
{
|
|
||||||
for (i = 0; i < MAX_MON_MOVES; i++)
|
|
||||||
{
|
{
|
||||||
if (gBattleMons[gBattlerAttacker].moves[i] == *choicedMoveAtk)
|
++gBattleScripting.atk49_state;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (i == MAX_MON_MOVES)
|
*choicedMoveAtk = gChosenMove;
|
||||||
*choicedMoveAtk = 0;
|
|
||||||
|
|
||||||
gBattleScripting.atk49_state++;
|
|
||||||
}
|
}
|
||||||
|
for (i = 0; i < MAX_MON_MOVES; ++i)
|
||||||
|
{
|
||||||
|
if (gBattleMons[gBattlerAttacker].moves[i] == *choicedMoveAtk)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (i == MAX_MON_MOVES)
|
||||||
|
*choicedMoveAtk = 0;
|
||||||
|
++gBattleScripting.atk49_state;
|
||||||
break;
|
break;
|
||||||
case ATK49_CHANGED_ITEMS: // changed held items
|
case ATK49_CHANGED_ITEMS: // changed held items
|
||||||
for (i = 0; i < gBattlersCount; i++)
|
for (i = 0; i < gBattlersCount; i++)
|
||||||
@ -6152,29 +6139,22 @@ static void atk69_adjustsetdamage(void) // The same as 0x7, except there's no ra
|
|||||||
RecordItemEffectBattle(gBattlerTarget, holdEffect);
|
RecordItemEffectBattle(gBattlerTarget, holdEffect);
|
||||||
gSpecialStatuses[gBattlerTarget].focusBanded = 1;
|
gSpecialStatuses[gBattlerTarget].focusBanded = 1;
|
||||||
}
|
}
|
||||||
if (gBattleMons[gBattlerTarget].status2 & STATUS2_SUBSTITUTE)
|
if (!(gBattleMons[gBattlerTarget].status2 & STATUS2_SUBSTITUTE)
|
||||||
goto END;
|
&& (gBattleMoves[gCurrentMove].effect == EFFECT_FALSE_SWIPE || gProtectStructs[gBattlerTarget].endured || gSpecialStatuses[gBattlerTarget].focusBanded)
|
||||||
if (gBattleMoves[gCurrentMove].effect != EFFECT_FALSE_SWIPE && !gProtectStructs[gBattlerTarget].endured
|
&& gBattleMons[gBattlerTarget].hp <= gBattleMoveDamage)
|
||||||
&& !gSpecialStatuses[gBattlerTarget].focusBanded)
|
|
||||||
goto END;
|
|
||||||
|
|
||||||
if (gBattleMons[gBattlerTarget].hp > gBattleMoveDamage)
|
|
||||||
goto END;
|
|
||||||
|
|
||||||
gBattleMoveDamage = gBattleMons[gBattlerTarget].hp - 1;
|
|
||||||
|
|
||||||
if (gProtectStructs[gBattlerTarget].endured)
|
|
||||||
{
|
{
|
||||||
gMoveResultFlags |= MOVE_RESULT_FOE_ENDURED;
|
gBattleMoveDamage = gBattleMons[gBattlerTarget].hp - 1;
|
||||||
|
if (gProtectStructs[gBattlerTarget].endured)
|
||||||
|
{
|
||||||
|
gMoveResultFlags |= MOVE_RESULT_FOE_ENDURED;
|
||||||
|
}
|
||||||
|
else if (gSpecialStatuses[gBattlerTarget].focusBanded)
|
||||||
|
{
|
||||||
|
gMoveResultFlags |= MOVE_RESULT_FOE_HUNG_ON;
|
||||||
|
gLastUsedItem = gBattleMons[gBattlerTarget].item;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (gSpecialStatuses[gBattlerTarget].focusBanded)
|
gBattlescriptCurrInstr++;
|
||||||
{
|
|
||||||
gMoveResultFlags |= MOVE_RESULT_FOE_HUNG_ON;
|
|
||||||
gLastUsedItem = gBattleMons[gBattlerTarget].item;
|
|
||||||
}
|
|
||||||
|
|
||||||
END:
|
|
||||||
gBattlescriptCurrInstr++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void atk6A_removeitem(void)
|
static void atk6A_removeitem(void)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user