@pkmn/sim 0.9.30 → 0.9.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/config/formats.js +58 -43
- package/build/cjs/config/formats.js.map +1 -1
- package/build/cjs/data/abilities.js +41 -41
- package/build/cjs/data/abilities.js.map +1 -1
- package/build/cjs/data/aliases.js +2 -2
- package/build/cjs/data/aliases.js.map +1 -1
- package/build/cjs/data/conditions.js +20 -20
- package/build/cjs/data/conditions.js.map +1 -1
- package/build/cjs/data/formats-data.js +1 -1
- package/build/cjs/data/items.js +5 -5
- package/build/cjs/data/items.js.map +1 -1
- package/build/cjs/data/mods/gen1/conditions.js +1 -2
- package/build/cjs/data/mods/gen1/conditions.js.map +1 -1
- package/build/cjs/data/mods/gen1/moves.js +2 -2
- package/build/cjs/data/mods/gen1/moves.js.map +1 -1
- package/build/cjs/data/mods/gen1/pokedex.js.map +1 -1
- package/build/cjs/data/mods/gen1/scripts.js +6 -6
- package/build/cjs/data/mods/gen1/scripts.js.map +1 -1
- package/build/cjs/data/mods/gen2/conditions.js +2 -2
- package/build/cjs/data/mods/gen2/conditions.js.map +1 -1
- package/build/cjs/data/mods/gen2/moves.js +3 -3
- package/build/cjs/data/mods/gen2/moves.js.map +1 -1
- package/build/cjs/data/mods/gen2/rulesets.js.map +1 -1
- package/build/cjs/data/mods/gen2/scripts.js +2 -2
- package/build/cjs/data/mods/gen2/scripts.js.map +1 -1
- package/build/cjs/data/mods/gen3/abilities.js +1 -1
- package/build/cjs/data/mods/gen3/abilities.js.map +1 -1
- package/build/cjs/data/mods/gen3/conditions.js +1 -1
- package/build/cjs/data/mods/gen3/conditions.js.map +1 -1
- package/build/cjs/data/mods/gen3/moves.js +5 -5
- package/build/cjs/data/mods/gen3/moves.js.map +1 -1
- package/build/cjs/data/mods/gen3/scripts.js +2 -2
- package/build/cjs/data/mods/gen3/scripts.js.map +1 -1
- package/build/cjs/data/mods/gen4/abilities.js +4 -4
- package/build/cjs/data/mods/gen4/abilities.js.map +1 -1
- package/build/cjs/data/mods/gen4/conditions.js +1 -1
- package/build/cjs/data/mods/gen4/conditions.js.map +1 -1
- package/build/cjs/data/mods/gen4/items.js +2 -2
- package/build/cjs/data/mods/gen4/items.js.map +1 -1
- package/build/cjs/data/mods/gen4/moves.js +22 -22
- package/build/cjs/data/mods/gen4/moves.js.map +1 -1
- package/build/cjs/data/mods/gen4/scripts.js +1 -1
- package/build/cjs/data/mods/gen4/scripts.js.map +1 -1
- package/build/cjs/data/mods/gen5/abilities.js +1 -1
- package/build/cjs/data/mods/gen5/abilities.js.map +1 -1
- package/build/cjs/data/mods/gen5/conditions.js +2 -2
- package/build/cjs/data/mods/gen5/conditions.js.map +1 -1
- package/build/cjs/data/mods/gen5/moves.js +6 -6
- package/build/cjs/data/mods/gen5/moves.js.map +1 -1
- package/build/cjs/data/mods/gen5/pokedex.js.map +1 -1
- package/build/cjs/data/mods/gen6/abilities.js +2 -2
- package/build/cjs/data/mods/gen6/abilities.js.map +1 -1
- package/build/cjs/data/mods/gen6/moves.js +1 -1
- package/build/cjs/data/mods/gen6/moves.js.map +1 -1
- package/build/cjs/data/mods/gen6/pokedex.js.map +1 -1
- package/build/cjs/data/mods/gen7/abilities.js.map +1 -1
- package/build/cjs/data/mods/gen7/moves.js +8 -8
- package/build/cjs/data/mods/gen7/moves.js.map +1 -1
- package/build/cjs/data/mods/gen7/pokedex.js.map +1 -1
- package/build/cjs/data/mods/gen8/abilities.js.map +1 -1
- package/build/cjs/data/mods/gen8/moves.js.map +1 -1
- package/build/cjs/data/mods/gen8/pokedex.js.map +1 -1
- package/build/cjs/data/moves.js +105 -103
- package/build/cjs/data/moves.js.map +1 -1
- package/build/cjs/data/pokedex.js.map +1 -1
- package/build/cjs/data/pokemongo.js.map +1 -1
- package/build/cjs/data/rulesets.js +0 -1
- package/build/cjs/data/rulesets.js.map +1 -1
- package/build/cjs/data/tags.js.map +1 -1
- package/build/cjs/data/text/abilities.js.map +1 -1
- package/build/cjs/data/text/default.js.map +1 -1
- package/build/cjs/data/text/items.js.map +1 -1
- package/build/cjs/data/text/moves.js.map +1 -1
- package/build/cjs/data/typechart.js.map +1 -1
- package/build/cjs/lib/utils.d.ts +5 -5
- package/build/cjs/lib/utils.js +21 -11
- package/build/cjs/lib/utils.js.map +1 -1
- package/build/cjs/sim/battle-actions.js +8 -8
- package/build/cjs/sim/battle-actions.js.map +1 -1
- package/build/cjs/sim/battle-queue.js +0 -1
- package/build/cjs/sim/battle-queue.js.map +1 -1
- package/build/cjs/sim/battle-stream.d.ts +3 -2
- package/build/cjs/sim/battle-stream.js +1 -1
- package/build/cjs/sim/battle-stream.js.map +1 -1
- package/build/cjs/sim/battle.d.ts +8 -8
- package/build/cjs/sim/battle.js +41 -44
- package/build/cjs/sim/battle.js.map +1 -1
- package/build/cjs/sim/dex-abilities.js.map +1 -1
- package/build/cjs/sim/dex-conditions.js +2 -2
- package/build/cjs/sim/dex-conditions.js.map +1 -1
- package/build/cjs/sim/dex-data.js +1 -1
- package/build/cjs/sim/dex-data.js.map +1 -1
- package/build/cjs/sim/dex-formats.d.ts +1 -0
- package/build/cjs/sim/dex-formats.js +95 -37
- package/build/cjs/sim/dex-formats.js.map +1 -1
- package/build/cjs/sim/dex-items.js.map +1 -1
- package/build/cjs/sim/dex-moves.js +2 -3
- package/build/cjs/sim/dex-moves.js.map +1 -1
- package/build/cjs/sim/exported-global-types.d.ts +1 -9
- package/build/cjs/sim/field.d.ts +1 -1
- package/build/cjs/sim/field.js +3 -3
- package/build/cjs/sim/field.js.map +1 -1
- package/build/cjs/sim/global-types.d.ts +1 -9
- package/build/cjs/sim/pokemon.d.ts +14 -25
- package/build/cjs/sim/pokemon.js +21 -22
- package/build/cjs/sim/pokemon.js.map +1 -1
- package/build/cjs/sim/side.d.ts +105 -11
- package/build/cjs/sim/side.js +6 -6
- package/build/cjs/sim/side.js.map +1 -1
- package/build/cjs/sim/state.d.ts +1 -1
- package/build/cjs/sim/state.js +3 -3
- package/build/cjs/sim/state.js.map +1 -1
- package/build/cjs/sim/team-validator.d.ts +2 -1
- package/build/cjs/sim/team-validator.js +37 -27
- package/build/cjs/sim/team-validator.js.map +1 -1
- package/build/cjs/sim/tools/random-player-ai.d.ts +4 -3
- package/build/cjs/sim/tools/random-player-ai.js +6 -7
- package/build/cjs/sim/tools/random-player-ai.js.map +1 -1
- package/build/cjs/sim/tools/runner.d.ts +2 -2
- package/build/cjs/sim/tools/runner.js +1 -1
- package/build/cjs/sim/tools/runner.js.map +1 -1
- package/build/esm/config/formats.mjs +58 -43
- package/build/esm/config/formats.mjs.map +1 -1
- package/build/esm/data/abilities.mjs +41 -41
- package/build/esm/data/abilities.mjs.map +1 -1
- package/build/esm/data/aliases.mjs +2 -2
- package/build/esm/data/aliases.mjs.map +1 -1
- package/build/esm/data/conditions.mjs +20 -20
- package/build/esm/data/conditions.mjs.map +1 -1
- package/build/esm/data/formats-data.mjs +1 -1
- package/build/esm/data/items.mjs +5 -5
- package/build/esm/data/items.mjs.map +1 -1
- package/build/esm/data/mods/gen1/conditions.mjs +1 -2
- package/build/esm/data/mods/gen1/conditions.mjs.map +1 -1
- package/build/esm/data/mods/gen1/moves.mjs +2 -2
- package/build/esm/data/mods/gen1/moves.mjs.map +1 -1
- package/build/esm/data/mods/gen1/pokedex.mjs.map +1 -1
- package/build/esm/data/mods/gen1/scripts.mjs +6 -6
- package/build/esm/data/mods/gen1/scripts.mjs.map +1 -1
- package/build/esm/data/mods/gen2/conditions.mjs +2 -2
- package/build/esm/data/mods/gen2/conditions.mjs.map +1 -1
- package/build/esm/data/mods/gen2/moves.mjs +3 -3
- package/build/esm/data/mods/gen2/moves.mjs.map +1 -1
- package/build/esm/data/mods/gen2/rulesets.mjs.map +1 -1
- package/build/esm/data/mods/gen2/scripts.mjs +2 -2
- package/build/esm/data/mods/gen2/scripts.mjs.map +1 -1
- package/build/esm/data/mods/gen3/abilities.mjs +1 -1
- package/build/esm/data/mods/gen3/abilities.mjs.map +1 -1
- package/build/esm/data/mods/gen3/conditions.mjs +1 -1
- package/build/esm/data/mods/gen3/conditions.mjs.map +1 -1
- package/build/esm/data/mods/gen3/moves.mjs +5 -5
- package/build/esm/data/mods/gen3/moves.mjs.map +1 -1
- package/build/esm/data/mods/gen3/scripts.mjs +2 -2
- package/build/esm/data/mods/gen3/scripts.mjs.map +1 -1
- package/build/esm/data/mods/gen4/abilities.mjs +4 -4
- package/build/esm/data/mods/gen4/abilities.mjs.map +1 -1
- package/build/esm/data/mods/gen4/conditions.mjs +1 -1
- package/build/esm/data/mods/gen4/conditions.mjs.map +1 -1
- package/build/esm/data/mods/gen4/items.mjs +2 -2
- package/build/esm/data/mods/gen4/items.mjs.map +1 -1
- package/build/esm/data/mods/gen4/moves.mjs +22 -22
- package/build/esm/data/mods/gen4/moves.mjs.map +1 -1
- package/build/esm/data/mods/gen4/scripts.mjs +1 -1
- package/build/esm/data/mods/gen4/scripts.mjs.map +1 -1
- package/build/esm/data/mods/gen5/abilities.mjs +1 -1
- package/build/esm/data/mods/gen5/abilities.mjs.map +1 -1
- package/build/esm/data/mods/gen5/conditions.mjs +2 -2
- package/build/esm/data/mods/gen5/conditions.mjs.map +1 -1
- package/build/esm/data/mods/gen5/moves.mjs +6 -6
- package/build/esm/data/mods/gen5/moves.mjs.map +1 -1
- package/build/esm/data/mods/gen5/pokedex.mjs.map +1 -1
- package/build/esm/data/mods/gen6/abilities.mjs +2 -2
- package/build/esm/data/mods/gen6/abilities.mjs.map +1 -1
- package/build/esm/data/mods/gen6/moves.mjs +1 -1
- package/build/esm/data/mods/gen6/moves.mjs.map +1 -1
- package/build/esm/data/mods/gen6/pokedex.mjs.map +1 -1
- package/build/esm/data/mods/gen7/abilities.mjs.map +1 -1
- package/build/esm/data/mods/gen7/moves.mjs +8 -8
- package/build/esm/data/mods/gen7/moves.mjs.map +1 -1
- package/build/esm/data/mods/gen7/pokedex.mjs.map +1 -1
- package/build/esm/data/mods/gen8/abilities.mjs.map +1 -1
- package/build/esm/data/mods/gen8/moves.mjs.map +1 -1
- package/build/esm/data/mods/gen8/pokedex.mjs.map +1 -1
- package/build/esm/data/moves.mjs +105 -103
- package/build/esm/data/moves.mjs.map +1 -1
- package/build/esm/data/pokedex.mjs.map +1 -1
- package/build/esm/data/pokemongo.mjs.map +1 -1
- package/build/esm/data/rulesets.mjs +0 -1
- package/build/esm/data/rulesets.mjs.map +1 -1
- package/build/esm/data/tags.mjs.map +1 -1
- package/build/esm/data/text/abilities.mjs.map +1 -1
- package/build/esm/data/text/default.mjs.map +1 -1
- package/build/esm/data/text/items.mjs.map +1 -1
- package/build/esm/data/text/moves.mjs.map +1 -1
- package/build/esm/data/typechart.mjs.map +1 -1
- package/build/esm/lib/utils.d.mts +5 -5
- package/build/esm/lib/utils.mjs +21 -11
- package/build/esm/lib/utils.mjs.map +1 -1
- package/build/esm/sim/battle-actions.mjs +8 -8
- package/build/esm/sim/battle-actions.mjs.map +1 -1
- package/build/esm/sim/battle-queue.mjs +0 -1
- package/build/esm/sim/battle-queue.mjs.map +1 -1
- package/build/esm/sim/battle-stream.d.mts +3 -2
- package/build/esm/sim/battle-stream.mjs +1 -1
- package/build/esm/sim/battle-stream.mjs.map +1 -1
- package/build/esm/sim/battle.d.mts +8 -8
- package/build/esm/sim/battle.mjs +41 -44
- package/build/esm/sim/battle.mjs.map +1 -1
- package/build/esm/sim/dex-abilities.mjs.map +1 -1
- package/build/esm/sim/dex-conditions.mjs +2 -2
- package/build/esm/sim/dex-conditions.mjs.map +1 -1
- package/build/esm/sim/dex-data.mjs +1 -1
- package/build/esm/sim/dex-data.mjs.map +1 -1
- package/build/esm/sim/dex-formats.d.mts +1 -0
- package/build/esm/sim/dex-formats.mjs +95 -37
- package/build/esm/sim/dex-formats.mjs.map +1 -1
- package/build/esm/sim/dex-items.mjs.map +1 -1
- package/build/esm/sim/dex-moves.mjs +2 -3
- package/build/esm/sim/dex-moves.mjs.map +1 -1
- package/build/esm/sim/exported-global-types.d.mts +1 -9
- package/build/esm/sim/field.d.mts +1 -1
- package/build/esm/sim/field.mjs +3 -3
- package/build/esm/sim/field.mjs.map +1 -1
- package/build/esm/sim/global-types.d.mts +1 -9
- package/build/esm/sim/pokemon.d.mts +14 -25
- package/build/esm/sim/pokemon.mjs +21 -22
- package/build/esm/sim/pokemon.mjs.map +1 -1
- package/build/esm/sim/side.d.mts +105 -11
- package/build/esm/sim/side.mjs +6 -6
- package/build/esm/sim/side.mjs.map +1 -1
- package/build/esm/sim/state.d.mts +1 -1
- package/build/esm/sim/state.mjs +3 -3
- package/build/esm/sim/state.mjs.map +1 -1
- package/build/esm/sim/team-validator.d.mts +2 -1
- package/build/esm/sim/team-validator.mjs +37 -27
- package/build/esm/sim/team-validator.mjs.map +1 -1
- package/build/esm/sim/tools/random-player-ai.d.mts +4 -3
- package/build/esm/sim/tools/random-player-ai.mjs +6 -7
- package/build/esm/sim/tools/random-player-ai.mjs.map +1 -1
- package/build/esm/sim/tools/runner.d.mts +2 -2
- package/build/esm/sim/tools/runner.mjs +1 -1
- package/build/esm/sim/tools/runner.mjs.map +1 -1
- package/package.json +1 -1
package/build/cjs/sim/field.js
CHANGED
|
@@ -29,7 +29,7 @@ class Field {
|
|
|
29
29
|
status = this.battle.dex.conditions.get(status);
|
|
30
30
|
if (!sourceEffect && this.battle.effect)
|
|
31
31
|
sourceEffect = this.battle.effect;
|
|
32
|
-
if (!source && this.battle.event
|
|
32
|
+
if (!source && this.battle.event?.target)
|
|
33
33
|
source = this.battle.event.target;
|
|
34
34
|
if (source === 'debug')
|
|
35
35
|
source = this.battle.sides[0].active[0];
|
|
@@ -121,7 +121,7 @@ class Field {
|
|
|
121
121
|
status = this.battle.dex.conditions.get(status);
|
|
122
122
|
if (!sourceEffect && this.battle.effect)
|
|
123
123
|
sourceEffect = this.battle.effect;
|
|
124
|
-
if (!source && this.battle.event
|
|
124
|
+
if (!source && this.battle.event?.target)
|
|
125
125
|
source = this.battle.event.target;
|
|
126
126
|
if (source === 'debug')
|
|
127
127
|
source = this.battle.sides[0].active[0];
|
|
@@ -175,7 +175,7 @@ class Field {
|
|
|
175
175
|
return this.battle.dex.conditions.getByID(this.terrain);
|
|
176
176
|
}
|
|
177
177
|
addPseudoWeather(status, source = null, sourceEffect = null) {
|
|
178
|
-
if (!source && this.battle.event
|
|
178
|
+
if (!source && this.battle.event?.target)
|
|
179
179
|
source = this.battle.event.target;
|
|
180
180
|
if (source === 'debug')
|
|
181
181
|
source = this.battle.sides[0].active[0];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"field.js","sourceRoot":"","sources":["../../../sim/field.ts"],"names":[],"mappings":";;;AAUA;;;;;GAKG;AAEH,
|
|
1
|
+
{"version":3,"file":"field.js","sourceRoot":"","sources":["../../../sim/field.ts"],"names":[],"mappings":"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"}
|
|
@@ -124,14 +124,6 @@ type ZMoveOptions = ({
|
|
|
124
124
|
move: string;
|
|
125
125
|
target: MoveTarget;
|
|
126
126
|
} | null)[];
|
|
127
|
-
interface DynamaxOptions {
|
|
128
|
-
maxMoves: ({
|
|
129
|
-
move: string;
|
|
130
|
-
target: MoveTarget;
|
|
131
|
-
disabled?: boolean;
|
|
132
|
-
})[];
|
|
133
|
-
gigantamax?: string;
|
|
134
|
-
}
|
|
135
127
|
interface BattleScriptsData {
|
|
136
128
|
gen: number;
|
|
137
129
|
}
|
|
@@ -145,7 +137,7 @@ interface ModdedBattleActions {
|
|
|
145
137
|
canTerastallize?: (this: BattleActions, pokemon: Pokemon) => string | null;
|
|
146
138
|
canUltraBurst?: (this: BattleActions, pokemon: Pokemon) => string | null;
|
|
147
139
|
canZMove?: (this: BattleActions, pokemon: Pokemon) => ZMoveOptions | void;
|
|
148
|
-
canDynamax?: (this: BattleActions, pokemon: Pokemon, skipChecks?: boolean) => DynamaxOptions | void;
|
|
140
|
+
canDynamax?: (this: BattleActions, pokemon: Pokemon, skipChecks?: boolean) => import('./side').DynamaxOptions | void;
|
|
149
141
|
forceSwitch?: (this: BattleActions, damage: SpreadMoveDamage, targets: SpreadMoveTargets, source: Pokemon, move: ActiveMove, moveData: ActiveMove, isSecondary?: boolean, isSelf?: boolean) => SpreadMoveDamage;
|
|
150
142
|
getActiveMaxMove?: (this: BattleActions, move: Move, pokemon: Pokemon) => ActiveMove;
|
|
151
143
|
getActiveZMove?: (this: BattleActions, move: Move, pokemon: Pokemon) => ActiveMove;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { Ability, ActiveMove, AnyObject, Battle, BoostsTable, Condition,
|
|
1
|
+
import { Ability, ActiveMove, AnyObject, Battle, BoostsTable, Condition, Effect, GenderName, ID, Item, Move, PokemonSet, PokemonSlot, Side, SideID, SparseBoostsTable, Species, StatIDExceptHP, StatsExceptHPTable, StatsTable } from './exported-global-types';
|
|
2
|
+
import type { DynamaxOptions, PokemonMoveRequestData, PokemonSwitchRequestData } from './side';
|
|
2
3
|
/** A Pokemon's move slot. */
|
|
3
4
|
interface MoveSlot {
|
|
4
5
|
id: ID;
|
|
@@ -31,11 +32,12 @@ export declare class Pokemon {
|
|
|
31
32
|
readonly battle: Battle;
|
|
32
33
|
readonly set: PokemonSet;
|
|
33
34
|
readonly name: string;
|
|
35
|
+
/** `` `${sideid}: ${name}` `` - used to refer to pokemon in the protocol */
|
|
34
36
|
readonly fullname: string;
|
|
35
37
|
readonly level: number;
|
|
36
38
|
readonly gender: GenderName;
|
|
37
39
|
readonly happiness: number;
|
|
38
|
-
readonly pokeball:
|
|
40
|
+
readonly pokeball: ID;
|
|
39
41
|
readonly dynamaxLevel: number;
|
|
40
42
|
readonly gigantamax: boolean;
|
|
41
43
|
/** Transform keeps the original pre-transformed Hidden Power in Gen 2-4. */
|
|
@@ -51,6 +53,11 @@ export declare class Pokemon {
|
|
|
51
53
|
* its field position in multi battles - use `getSlot()` for that.
|
|
52
54
|
*/
|
|
53
55
|
position: number;
|
|
56
|
+
/**
|
|
57
|
+
* Information about this pokemon visible to opponents when in battle
|
|
58
|
+
* (species, gender, level, shininess, tera state).
|
|
59
|
+
* @see https://github.com/smogon/pokemon-showdown/blob/master/sim/SIM-PROTOCOL.md#identifying-pok%C3%A9mon
|
|
60
|
+
*/
|
|
54
61
|
details: string;
|
|
55
62
|
baseSpecies: Species;
|
|
56
63
|
species: Species;
|
|
@@ -308,10 +315,10 @@ export declare class Pokemon {
|
|
|
308
315
|
* Sky Drop, which remove all choice (no dynamax, switching, etc).
|
|
309
316
|
* Don't use it for "soft locks" like Choice Band.
|
|
310
317
|
*/
|
|
311
|
-
getLockedMove():
|
|
312
|
-
getMoves(lockedMove?:
|
|
318
|
+
getLockedMove(): ID | null;
|
|
319
|
+
getMoves(lockedMove?: ID | null, restrictData?: boolean): {
|
|
313
320
|
move: string;
|
|
314
|
-
id:
|
|
321
|
+
id: ID;
|
|
315
322
|
disabled?: string | boolean;
|
|
316
323
|
disabledSource?: string;
|
|
317
324
|
target?: string;
|
|
@@ -321,26 +328,8 @@ export declare class Pokemon {
|
|
|
321
328
|
/** This should be passed the base move and not the corresponding max move so we can check how much PP is left. */
|
|
322
329
|
maxMoveDisabled(baseMove: Move | string): boolean;
|
|
323
330
|
getDynamaxRequest(skipChecks?: boolean): DynamaxOptions | undefined;
|
|
324
|
-
getMoveRequestData():
|
|
325
|
-
|
|
326
|
-
move: string;
|
|
327
|
-
id: string;
|
|
328
|
-
target?: string;
|
|
329
|
-
disabled?: string | boolean;
|
|
330
|
-
}[];
|
|
331
|
-
maybeDisabled?: boolean;
|
|
332
|
-
trapped?: boolean;
|
|
333
|
-
maybeTrapped?: boolean;
|
|
334
|
-
canMegaEvo?: boolean;
|
|
335
|
-
canMegaEvoX?: boolean;
|
|
336
|
-
canMegaEvoY?: boolean;
|
|
337
|
-
canUltraBurst?: boolean;
|
|
338
|
-
canZMove?: AnyObject | null;
|
|
339
|
-
canDynamax?: boolean;
|
|
340
|
-
maxMoves?: DynamaxOptions;
|
|
341
|
-
canTerastallize?: string;
|
|
342
|
-
};
|
|
343
|
-
getSwitchRequestData(forAlly?: boolean): AnyObject;
|
|
331
|
+
getMoveRequestData(): PokemonMoveRequestData;
|
|
332
|
+
getSwitchRequestData(forAlly?: boolean): PokemonSwitchRequestData;
|
|
344
333
|
isLastActive(): boolean;
|
|
345
334
|
positiveBoosts(): number;
|
|
346
335
|
getCappedBoost(boosts: SparseBoostsTable): Partial<BoostsTable>;
|
package/build/cjs/sim/pokemon.js
CHANGED
|
@@ -79,7 +79,7 @@ class Pokemon {
|
|
|
79
79
|
}
|
|
80
80
|
this.speciesState = this.battle.initEffectState({ id: this.species.id });
|
|
81
81
|
this.name = set.name.substr(0, 20);
|
|
82
|
-
this.fullname = this.side.id
|
|
82
|
+
this.fullname = `${this.side.id}: ${this.name}`;
|
|
83
83
|
set.level = this.battle.clampIntRange(set.adjustLevel || set.level || 100, 1, 9999);
|
|
84
84
|
this.level = set.level;
|
|
85
85
|
const genders = { M: 'M', F: 'F', N: 'N' };
|
|
@@ -87,7 +87,7 @@ class Pokemon {
|
|
|
87
87
|
if (this.gender === 'N')
|
|
88
88
|
this.gender = '';
|
|
89
89
|
this.happiness = typeof set.happiness === 'number' ? this.battle.clampIntRange(set.happiness, 0, 255) : 255;
|
|
90
|
-
this.pokeball = this.set.pokeball || 'pokeball';
|
|
90
|
+
this.pokeball = (0, dex_1.toID)(this.set.pokeball) || 'pokeball';
|
|
91
91
|
this.dynamaxLevel = typeof set.dynamaxLevel === 'number' ? this.battle.clampIntRange(set.dynamaxLevel, 0, 10) : 10;
|
|
92
92
|
this.gigantamax = this.set.gigantamax || false;
|
|
93
93
|
this.baseMoveSlots = [];
|
|
@@ -104,7 +104,7 @@ class Pokemon {
|
|
|
104
104
|
set.hpType = move.type;
|
|
105
105
|
move = this.battle.dex.moves.get('hiddenpower');
|
|
106
106
|
}
|
|
107
|
-
let basepp =
|
|
107
|
+
let basepp = move.noPPBoosts ? move.pp : move.pp * 8 / 5;
|
|
108
108
|
if (this.battle.gen < 3)
|
|
109
109
|
basepp = Math.min(61, basepp);
|
|
110
110
|
this.baseMoveSlots.push({
|
|
@@ -255,15 +255,15 @@ class Pokemon {
|
|
|
255
255
|
name = this.species.baseSpecies;
|
|
256
256
|
if (!level)
|
|
257
257
|
level = this.level;
|
|
258
|
-
return name + (level === 100 ? '' :
|
|
259
|
-
(this.gender === '' ? '' :
|
|
258
|
+
return name + (level === 100 ? '' : `, L${level}`) +
|
|
259
|
+
(this.gender === '' ? '' : `, ${this.gender}`) + (this.set.shiny ? ', shiny' : '');
|
|
260
260
|
}
|
|
261
261
|
updateSpeed() {
|
|
262
262
|
this.speed = this.getActionSpeed();
|
|
263
263
|
}
|
|
264
264
|
calculateStat(statName, boost, modifier, statUser) {
|
|
265
265
|
statName = (0, dex_1.toID)(statName);
|
|
266
|
-
// @ts-
|
|
266
|
+
// @ts-expect-error type checking prevents 'hp' from being passed, but we're paranoid
|
|
267
267
|
if (statName === 'hp')
|
|
268
268
|
throw new Error("Please read `maxhp` directly");
|
|
269
269
|
// base stat
|
|
@@ -299,7 +299,7 @@ class Pokemon {
|
|
|
299
299
|
}
|
|
300
300
|
getStat(statName, unboosted, unmodified) {
|
|
301
301
|
statName = (0, dex_1.toID)(statName);
|
|
302
|
-
// @ts-
|
|
302
|
+
// @ts-expect-error type checking prevents 'hp' from being passed, but we're paranoid
|
|
303
303
|
if (statName === 'hp')
|
|
304
304
|
throw new Error("Please read `maxhp` directly");
|
|
305
305
|
// base stat
|
|
@@ -656,13 +656,13 @@ class Pokemon {
|
|
|
656
656
|
for (const moveSlot of this.moveSlots) {
|
|
657
657
|
let moveName = moveSlot.move;
|
|
658
658
|
if (moveSlot.id === 'hiddenpower') {
|
|
659
|
-
moveName =
|
|
659
|
+
moveName = `Hidden Power ${this.hpType}`;
|
|
660
660
|
if (this.battle.gen < 6)
|
|
661
|
-
moveName +=
|
|
661
|
+
moveName += ` ${this.hpPower}`;
|
|
662
662
|
}
|
|
663
663
|
else if (moveSlot.id === 'return' || moveSlot.id === 'frustration') {
|
|
664
664
|
const basePowerCallback = this.battle.dex.moves.get(moveSlot.id).basePowerCallback;
|
|
665
|
-
moveName +=
|
|
665
|
+
moveName += ` ${basePowerCallback(this)}`;
|
|
666
666
|
}
|
|
667
667
|
let target = moveSlot.target;
|
|
668
668
|
switch (moveSlot.id) {
|
|
@@ -818,11 +818,11 @@ class Pokemon {
|
|
|
818
818
|
},
|
|
819
819
|
moves: this[forAlly ? 'baseMoves' : 'moves'].map(move => {
|
|
820
820
|
if (move === 'hiddenpower') {
|
|
821
|
-
return move
|
|
821
|
+
return `${move}${(0, dex_1.toID)(this.hpType)}${this.battle.gen < 6 ? '' : this.hpPower}`;
|
|
822
822
|
}
|
|
823
823
|
if (move === 'frustration' || move === 'return') {
|
|
824
824
|
const basePowerCallback = this.battle.dex.moves.get(move).basePowerCallback;
|
|
825
|
-
return move
|
|
825
|
+
return `${move}${basePowerCallback(this)}`;
|
|
826
826
|
}
|
|
827
827
|
return move;
|
|
828
828
|
}),
|
|
@@ -924,8 +924,9 @@ class Pokemon {
|
|
|
924
924
|
const species = pokemon.species;
|
|
925
925
|
if (pokemon.fainted || this.illusion || pokemon.illusion || (pokemon.volatiles['substitute'] && this.battle.gen >= 5) ||
|
|
926
926
|
(pokemon.transformed && this.battle.gen >= 2) || (this.transformed && this.battle.gen >= 5) ||
|
|
927
|
-
species.name === 'Eternatus-Eternamax' ||
|
|
928
|
-
(this.terastallized || pokemon.terastallized)) ||
|
|
927
|
+
species.name === 'Eternatus-Eternamax' ||
|
|
928
|
+
(['Ogerpon', 'Terapagos'].includes(species.baseSpecies) && (this.terastallized || pokemon.terastallized)) ||
|
|
929
|
+
this.terastallized === 'Stellar') {
|
|
929
930
|
return false;
|
|
930
931
|
}
|
|
931
932
|
if (this.battle.dex.currentMod === 'gen1stadium' && (species.name === 'Ditto' ||
|
|
@@ -1303,7 +1304,7 @@ class Pokemon {
|
|
|
1303
1304
|
return;
|
|
1304
1305
|
if (d < 1)
|
|
1305
1306
|
d = 1;
|
|
1306
|
-
d
|
|
1307
|
+
d -= this.hp;
|
|
1307
1308
|
this.hp += d;
|
|
1308
1309
|
if (this.hp > this.maxhp) {
|
|
1309
1310
|
d -= this.hp - this.maxhp;
|
|
@@ -1347,8 +1348,7 @@ class Pokemon {
|
|
|
1347
1348
|
}
|
|
1348
1349
|
return false;
|
|
1349
1350
|
}
|
|
1350
|
-
if (!ignoreImmunities && status.id &&
|
|
1351
|
-
!(source?.hasAbility('corrosion') && ['tox', 'psn'].includes(status.id))) {
|
|
1351
|
+
if (!ignoreImmunities && status.id && !(source?.hasAbility('corrosion') && ['tox', 'psn'].includes(status.id))) {
|
|
1352
1352
|
// the game currently never ignores immunities
|
|
1353
1353
|
if (!this.runStatusImmunity(status.id === 'tox' ? 'psn' : status.id)) {
|
|
1354
1354
|
this.battle.debug('immune to status');
|
|
@@ -1410,7 +1410,7 @@ class Pokemon {
|
|
|
1410
1410
|
return false;
|
|
1411
1411
|
if (!sourceEffect && this.battle.effect)
|
|
1412
1412
|
sourceEffect = this.battle.effect;
|
|
1413
|
-
if (!source && this.battle.event
|
|
1413
|
+
if (!source && this.battle.event?.target)
|
|
1414
1414
|
source = this.battle.event.target;
|
|
1415
1415
|
const item = this.getItem();
|
|
1416
1416
|
if (sourceEffect?.effectType === 'Item' && this.item !== sourceEffect.id && source === this) {
|
|
@@ -1451,7 +1451,7 @@ class Pokemon {
|
|
|
1451
1451
|
return false;
|
|
1452
1452
|
if (!sourceEffect && this.battle.effect)
|
|
1453
1453
|
sourceEffect = this.battle.effect;
|
|
1454
|
-
if (!source && this.battle.event
|
|
1454
|
+
if (!source && this.battle.event?.target)
|
|
1455
1455
|
source = this.battle.event.target;
|
|
1456
1456
|
const item = this.getItem();
|
|
1457
1457
|
if (sourceEffect?.effectType === 'Item' && this.item !== sourceEffect.id && source === this) {
|
|
@@ -1461,7 +1461,7 @@ class Pokemon {
|
|
|
1461
1461
|
if (this.battle.runEvent('UseItem', this, null, null, item)) {
|
|
1462
1462
|
switch (item.id) {
|
|
1463
1463
|
case 'redcard':
|
|
1464
|
-
this.battle.add('-enditem', this, item,
|
|
1464
|
+
this.battle.add('-enditem', this, item, `[of] ${source}`);
|
|
1465
1465
|
break;
|
|
1466
1466
|
default:
|
|
1467
1467
|
if (item.isGem) {
|
|
@@ -1571,8 +1571,7 @@ class Pokemon {
|
|
|
1571
1571
|
}
|
|
1572
1572
|
this.battle.singleEvent('End', this.battle.dex.abilities.get(oldAbility), this.abilityState, this, source);
|
|
1573
1573
|
if (this.battle.effect && this.battle.effect.effectType === 'Move' && !isFromFormeChange) {
|
|
1574
|
-
this.battle.add('-endability', this, this.battle.dex.abilities.get(oldAbility),
|
|
1575
|
-
this.battle.dex.moves.get(this.battle.effect.id));
|
|
1574
|
+
this.battle.add('-endability', this, this.battle.dex.abilities.get(oldAbility), `[from] move: ${this.battle.dex.moves.get(this.battle.effect.id)}`);
|
|
1576
1575
|
}
|
|
1577
1576
|
this.ability = ability.id;
|
|
1578
1577
|
this.abilityState = this.battle.initEffectState({ id: ability.id, target: this });
|