Spaces:
Running
Running
File size: 9,030 Bytes
5c2ed06 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 |
Teams
=====
Pokémon Showdown uses three teams formats:
1. Export format - for humans to read/write
2. JSON format - for computers to read/write
3. Packed format - compressed, for sending/saving/logging
Teams sent over a text format, such as the console command `/utm` or the command-line `./pokemon-showdown validate-team`, will usually used packed format. In addition, backups will automatically switch to packed format if you have enough teams.
Variables storing teams inside PS's codebase will generally be stored in JSON format. Because we use TypeScript, this will be pretty obvious; the type will be `PokemonSet[]` (for JSON format) rather than `string` (for packed format).
Export format is basically only used by the client, to show users.
Export format
-------------
Export format looks like this:
```
Articuno @ Leftovers
Ability: Pressure
EVs: 252 HP / 252 SpA / 4 SpD
Modest Nature
IVs: 30 SpA / 30 SpD
- Ice Beam
- Hurricane
- Substitute
- Roost
Ludicolo @ Life Orb
Ability: Swift Swim
EVs: 4 HP / 252 SpA / 252 Spe
Modest Nature
- Surf
- Giga Drain
- Ice Beam
- Rain Dance
Volbeat (M) @ Damp Rock
Ability: Prankster
EVs: 248 HP / 252 Def / 8 SpD
Bold Nature
- Tail Glow
- Baton Pass
- Encore
- Rain Dance
Seismitoad @ Life Orb
Ability: Swift Swim
EVs: 252 SpA / 4 SpD / 252 Spe
Modest Nature
- Hydro Pump
- Earth Power
- Stealth Rock
- Rain Dance
Alomomola @ Damp Rock
Ability: Regenerator
EVs: 252 HP / 252 Def / 4 SpD
Bold Nature
- Wish
- Protect
- Toxic
- Rain Dance
Armaldo @ Leftovers
Ability: Swift Swim
EVs: 128 HP / 252 Atk / 4 Def / 124 Spe
Adamant Nature
- X-Scissor
- Stone Edge
- Aqua Tail
- Rapid Spin
```
It's used for teambuilder import/export features, and not much else. But as a user, this is the only format you'll see.
JSON format
-----------
JSON format looks like this:
```json
[
{
"name": "",
"species": "Articuno",
"gender": "",
"item": "Leftovers",
"ability": "Pressure",
"evs": {"hp": 252, "atk": 0, "def": 0, "spa": 252, "spd": 4, "spe": 0},
"nature": "Modest",
"ivs": {"hp": 31, "atk": 31, "def": 31, "spa": 30, "spd": 30, "spe": 31},
"moves": ["Ice Beam", "Hurricane", "Substitute", "Roost"]
},
{
"name": "",
"species": "Ludicolo",
"gender": "",
"item": "Life Orb",
"ability": "Swift Swim",
"evs": {"hp": 4, "atk": 0, "def": 0, "spa": 252, "spd": 0, "spe": 252},
"nature": "Modest",
"moves": ["Surf", "Giga Drain", "Ice Beam", "Rain Dance"]
},
{
"name": "",
"species": "Volbeat",
"gender": "M",
"item": "Damp Rock",
"ability": "Prankster",
"evs": {"hp": 248, "atk": 0, "def": 252, "spa": 0, "spd": 8, "spe": 0},
"nature": "Bold",
"moves": ["Tail Glow", "Baton Pass", "Encore", "Rain Dance"]
},
{
"name": "",
"species": "Seismitoad",
"gender": "",
"item": "Life Orb",
"ability": "Swift Swim",
"evs": {"hp": 0, "atk": 0, "def": 0, "spa": 252, "spd": 4, "spe": 252},
"nature": "Modest",
"moves": ["Hydro Pump", "Earth Power", "Stealth Rock", "Rain Dance"]
},
{
"name": "",
"species": "Alomomola",
"gender": "",
"item": "Damp Rock",
"ability": "Regenerator",
"evs": {"hp": 252, "atk": 0, "def": 252, "spa": 0, "spd": 4, "spe": 0},
"nature": "Bold",
"moves": ["Wish", "Protect", "Toxic", "Rain Dance"]
},
{
"name": "",
"species": "Armaldo",
"gender": "",
"item": "Leftovers",
"ability": "Swift Swim",
"evs": {"hp": 128, "atk": 252, "def": 4, "spa": 0, "spd": 0, "spe": 124},
"nature": "Adamant",
"moves": ["X-Scissor", "Stone Edge", "Aqua Tail", "Rapid Spin"]
}
]
```
Packed format
-------------
Packed format looks like this:
```
Articuno||leftovers|pressure|icebeam,hurricane,substitute,roost|Modest|252,,,252,4,||,,,30,30,|||]
Ludicolo||lifeorb|swiftswim|surf,gigadrain,icebeam,raindance|Modest|4,,,252,,252|||||]
Volbeat||damprock|prankster|tailglow,batonpass,encore,raindance|Bold|248,,252,,8,|M||||]
Seismitoad||lifeorb|swiftswim|hydropump,earthpower,stealthrock,raindance|Modest|,,,252,4,252|||||]
Alomomola||damprock|regenerator|wish,protect,toxic,raindance|Bold|252,,252,,4,|||||]
Armaldo||leftovers|swiftswim|xscissor,stoneedge,aquatail,rapidspin|Adamant|128,252,4,,,124|||||
```
(Line breaks added for readability - this is all one line normally.)
The format is a list of pokemon delimited by `]`, where every Pokémon is:
```
NICKNAME|SPECIES|ITEM|ABILITY|MOVES|NATURE|EVS|GENDER|IVS|SHINY|LEVEL|HAPPINESS,POKEBALL,HIDDENPOWERTYPE,GIGANTAMAX,DYNAMAXLEVEL,TERATYPE
```
- `SPECIES` is left blank if it's identical to `NICKNAME`
- `ABILITY` is `0`, `1`, or `H` if it's the ability from the corresponding slot
for the Pokémon. It can also be an ability string, for Hackmons etc.
- `MOVES` is a comma-separated list of move IDs.
- `NATURE` left blank means Serious, except in Gen 1-2, where it means no Nature.
- `EVS` and `IVS` are comma-separated in standard order:
HP, Atk, Def, SpA, SpD, Spe. EVs left blank are 0, IVs left blank are 31.
If all EVs or IVs are blank, the commas can all be left off.
- `EVS` represent AVs in Pokémon Let's Go.
- `IVS` represent DVs in Gen 1-2. The IV will be divided by 2 and rounded down,
to become DVs (so the default of 31 IVs is converted to 15 DVs).
- `IVS` is post-hyper-training: pre-hyper-training IVs are represented in
`HIDDENPOWERTYPE`
- `SHINY` is `S` for shiny, and blank for non-shiny.
- `LEVEL` is left blank for level 100.
- `HAPPINESS` is left blank for 255.
- `POKEBALL` is left blank if it's a regular Poké Ball.
- `HIDDENPOWERTYPE` is left blank if the Pokémon is not Hyper Trained, if
Hyper Training doesn't affect IVs, or if it's represented by a move in
the moves list.
- `GIGANTAMAX` is `G` for Gmax, blank for non-Gmax.
- `DYNAMAXLEVEL` is left blank for 10.
- `TERATYPE` if left blank will default to the Pokémon's first type.
- If `POKEBALL`, `HIDDENPOWERTYPE`, `GIGANTAMAX`, `DYNAMAXLEVEL` and `TERATYPE`
are all blank, the commas will be left off.
Converting between formats
--------------------------
`Teams.unpack(packedTeam: string): PokemonSet[]`
- Converts a packed team to a JSON team
`Teams.pack(team: PokemonSet[]): string`
- Converts a JSON team to a packed team
`Teams.import(exportedTeam: string): PokemonSet[]`
- Converts a team in any string format (JSON, exported, or packed) to a JSON team
`Teams.export(team: PokemonSet[]): string`
- Converts a JSON team to an export team
`Teams.exportSet(set: PokemonSet): string`
- Converts a JSON set to export format
To convert from export to packed (or vice versa), just round-trip through PokemonSet: `Teams.export(Teams.unpack(packedTeam))` will produce an exported team.
Example use:
```js
const {Teams} = require('pokemon-showdown');
console.log(JSON.stringify(Teams.unpack(
`Articuno||leftovers|pressure|icebeam,hurricane,substitute,roost|Modest|252,,,252,4,||,,,30,30,|||]Ludicolo||lifeorb|swiftswim|surf,gigadrain,icebeam,raindance|Modest|4,,,252,,252|||||]Volbeat||damprock|prankster|tailglow,batonpass,encore,raindance|Bold|248,,252,,8,|M||||]Seismitoad||lifeorb|swiftswim|hydropump,earthpower,stealthrock,raindance|Modest|,,,252,4,252|||||]Alomomola||damprock|regenerator|wish,protect,toxic,raindance|Bold|252,,252,,4,|||||]Armaldo||leftovers|swiftswim|xscissor,stoneedge,aquatail,rapidspin|Adamant|128,252,4,,,124|||||`
)));
// will log the team to console in JSON format
```
Random team generator
---------------------
`Teams.generate(format: Format | string, options?: {seed: number[4]}): PokemonSet[]`
- Generate a team for a random format
Team validator
--------------
The team validator is separate from the simulator.
In JavaScript, it's available directly as a function:
```js
const {Teams, TeamValidator} = require('pokemon-showdown');
const validator = new TeamValidator('gen6nu');
const output = validator.validateTeam(
Teams.unpack(
`Articuno||leftovers|pressure|icebeam,hurricane,substitute,roost|Modest|252,,,252,4,||,,,30,30,|||]Ludicolo||lifeorb|swiftswim|surf,gigadrain,icebeam,raindance|Modest|4,,,252,,252|||||]Volbeat||damprock|prankster|tailglow,batonpass,encore,raindance|Bold|248,,252,,8,|M||||]Seismitoad||lifeorb|swiftswim|hydropump,earthpower,stealthrock,raindance|Modest|,,,252,4,252|||||]Alomomola||damprock|regenerator|wish,protect,toxic,raindance|Bold|252,,252,,4,|||||]Armaldo||leftovers|swiftswim|xscissor,stoneedge,aquatail,rapidspin|Adamant|128,252,4,,,124|||||`
)
);
```
`output` will be an array of problems, if it's not a legal team, or `null`, if it's a legal team.
Command-line API
----------------
If you're not using JavaScript, all of these APIs (conversion, generating random teams, validating teams) are available via the commandline API: [COMMANDLINE.md](./../COMMANDLINE.md).
They use standard IO, so any programming language supporting fork/exec should be able to call into them.
|