mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2025-01-15 16:12:12 +01:00
Fixed Comatose AI checks
This commit is contained in:
parent
8d8819b797
commit
0b8285737a
@ -144,6 +144,7 @@ bool32 AnyPartyMemberStatused(u8 battlerId, bool32 checkSoundproof);
|
|||||||
u32 ShouldTryToFlinch(u8 battlerAtk, u8 battlerDef, u16 atkAbility, u16 defAbility, u16 move);
|
u32 ShouldTryToFlinch(u8 battlerAtk, u8 battlerDef, u16 atkAbility, u16 defAbility, u16 move);
|
||||||
bool32 ShouldTrap(u8 battlerAtk, u8 battlerDef, u16 move);
|
bool32 ShouldTrap(u8 battlerAtk, u8 battlerDef, u16 move);
|
||||||
bool32 IsWakeupTurn(u8 battler);
|
bool32 IsWakeupTurn(u8 battler);
|
||||||
|
bool32 AI_IsBattlerAsleepOrComatose(u8 battlerId);
|
||||||
|
|
||||||
// partner logic
|
// partner logic
|
||||||
u16 GetAllyChosenMove(u8 battlerId);
|
u16 GetAllyChosenMove(u8 battlerId);
|
||||||
|
@ -974,7 +974,7 @@ static s16 AI_CheckBadMove(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case EFFECT_DREAM_EATER:
|
case EFFECT_DREAM_EATER:
|
||||||
if (!(gBattleMons[battlerDef].status1 & STATUS1_SLEEP) || AI_DATA->abilities[battlerDef] == ABILITY_COMATOSE)
|
if (!AI_IsBattlerAsleepOrComatose(battlerDef))
|
||||||
score -= 8;
|
score -= 8;
|
||||||
else if (effectiveness == AI_EFFECTIVENESS_x0)
|
else if (effectiveness == AI_EFFECTIVENESS_x0)
|
||||||
score -= 10;
|
score -= 10;
|
||||||
@ -1453,7 +1453,7 @@ static s16 AI_CheckBadMove(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
break;
|
break;
|
||||||
case EFFECT_SNORE:
|
case EFFECT_SNORE:
|
||||||
case EFFECT_SLEEP_TALK:
|
case EFFECT_SLEEP_TALK:
|
||||||
if (IsWakeupTurn(battlerAtk) || (!(gBattleMons[battlerAtk].status1 & STATUS1_SLEEP) || AI_DATA->abilities[battlerAtk] != ABILITY_COMATOSE))
|
if (IsWakeupTurn(battlerAtk) || !AI_IsBattlerAsleepOrComatose(battlerAtk))
|
||||||
score -= 10; // if mon will wake up, is not asleep, or is not comatose
|
score -= 10; // if mon will wake up, is not asleep, or is not comatose
|
||||||
break;
|
break;
|
||||||
case EFFECT_MEAN_LOOK:
|
case EFFECT_MEAN_LOOK:
|
||||||
@ -1463,7 +1463,7 @@ static s16 AI_CheckBadMove(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
case EFFECT_NIGHTMARE:
|
case EFFECT_NIGHTMARE:
|
||||||
if (gBattleMons[battlerDef].status2 & STATUS2_NIGHTMARE)
|
if (gBattleMons[battlerDef].status2 & STATUS2_NIGHTMARE)
|
||||||
score -= 10;
|
score -= 10;
|
||||||
else if (!(gBattleMons[battlerDef].status1 & STATUS1_SLEEP) || AI_DATA->abilities[battlerDef] == ABILITY_COMATOSE)
|
else if (!AI_IsBattlerAsleepOrComatose(battlerDef))
|
||||||
score -= 8;
|
score -= 8;
|
||||||
else if (DoesPartnerHaveSameMoveEffect(BATTLE_PARTNER(battlerAtk), battlerDef, move, AI_DATA->partnerMove))
|
else if (DoesPartnerHaveSameMoveEffect(BATTLE_PARTNER(battlerAtk), battlerDef, move, AI_DATA->partnerMove))
|
||||||
score -= 10;
|
score -= 10;
|
||||||
@ -3780,7 +3780,7 @@ static s16 AI_CheckViability(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
case EFFECT_NIGHTMARE:
|
case EFFECT_NIGHTMARE:
|
||||||
if (AI_DATA->abilities[battlerDef] != ABILITY_MAGIC_GUARD
|
if (AI_DATA->abilities[battlerDef] != ABILITY_MAGIC_GUARD
|
||||||
&& !(gBattleMons[battlerDef].status2 & STATUS2_NIGHTMARE)
|
&& !(gBattleMons[battlerDef].status2 & STATUS2_NIGHTMARE)
|
||||||
&& (AI_DATA->abilities[battlerDef] == ABILITY_COMATOSE || gBattleMons[battlerDef].status1 & STATUS1_SLEEP))
|
&& AI_IsBattlerAsleepOrComatose(battlerDef))
|
||||||
{
|
{
|
||||||
score += 5;
|
score += 5;
|
||||||
if (IsBattlerTrapped(battlerDef, TRUE))
|
if (IsBattlerTrapped(battlerDef, TRUE))
|
||||||
|
@ -3749,3 +3749,8 @@ bool32 ShouldUseZMove(u8 battlerAtk, u8 battlerDef, u16 chosenMove)
|
|||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool32 AI_IsBattlerAsleepOrComatose(u8 battlerId)
|
||||||
|
{
|
||||||
|
return (gBattleMons[battlerId].status1 & STATUS1_SLEEP) || AI_DATA->abilities[battlerId] == ABILITY_COMATOSE;
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user