From 86ebd0c5e5858a576d88556d36862d548c33596e Mon Sep 17 00:00:00 2001 From: NightKev <34855794+DayKev@users.noreply.github.com> Date: Mon, 22 Jul 2024 16:57:30 -0700 Subject: [PATCH] [Bug] Ability changing on evolution fix (#2995) * Prevent Pokemon with their second ability from evolving into their HA * Add check for fusions too --- src/field/pokemon.ts | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/src/field/pokemon.ts b/src/field/pokemon.ts index 9a7682040cd..a2d00792faf 100644 --- a/src/field/pokemon.ts +++ b/src/field/pokemon.ts @@ -3295,14 +3295,26 @@ export class PlayerPokemon extends Pokemon { } this.generateName(); if (!isFusion) { - const abilityCount = this.getSpeciesForm().getAbilityCount(); - if (this.abilityIndex >= abilityCount) { // Shouldn't happen - this.abilityIndex = abilityCount - 1; + // If a pokemon has its second ability and it evolves into a pokemon that doesn't have a second ability, switch to its first ability instead of its hidden ability + if (this.getSpeciesForm().ability2 === Abilities.NONE && this.abilityIndex === 1) { + this.abilityIndex = 0; + } + // Prevent pokemon with an illegal ability value from breaking things too badly + const abilityCount = this.getSpeciesForm().getAbilityCount(); + if (this.abilityIndex >= abilityCount) { + console.warn("this.abilityIndex is somehow an illegal value, please report this"); + console.warn(this.abilityIndex); + this.abilityIndex = 0; + } + } else { // Do the same as above, but for fusions + if (this.getFusionSpeciesForm().ability2 === Abilities.NONE && this.fusionAbilityIndex === 1) { + this.fusionAbilityIndex = 0; } - } else { const abilityCount = this.getFusionSpeciesForm().getAbilityCount(); - if (this.fusionAbilityIndex >= abilityCount) {// Shouldn't happen - this.fusionAbilityIndex = abilityCount - 1; + if (this.fusionAbilityIndex >= abilityCount) { + console.warn("this.fusionAbilityIndex is somehow an illegal value, please report this"); + console.warn(this.fusionAbilityIndex); + this.fusionAbilityIndex = 0; } } this.compatibleTms.splice(0, this.compatibleTms.length);