From a999787cb84e8363509ad72d92be8f1fc8b7d321 Mon Sep 17 00:00:00 2001 From: Rangi Date: Sun, 17 Feb 2019 13:18:38 -0500 Subject: [PATCH] Update documentation: - Apply more edits from #595 - Move music ID behavior from the wiki to docs - Move assembly programming links from docs to the wiki - Describe why the TM item gaps exist --- FAQ.md | 3 +- docs/assembly_programming.md | 25 ---- docs/bugs_and_glitches.md | 24 ++-- docs/design_flaws.md | 167 +++++++++++++++++++++++++- docs/images/hp_exp_bar_border.png | Bin 116 -> 166 bytes docs/images/hp_exp_bar_border_fix.png | Bin 166 -> 0 bytes docs/images/port.png | Bin 1048 -> 1526 bytes docs/images/port_fix.png | Bin 1526 -> 0 bytes engine/battle/core.asm | 8 +- 9 files changed, 181 insertions(+), 46 deletions(-) delete mode 100644 docs/assembly_programming.md delete mode 100644 docs/images/hp_exp_bar_border_fix.png delete mode 100644 docs/images/port_fix.png diff --git a/FAQ.md b/FAQ.md index a9f168442..924ed5117 100644 --- a/FAQ.md +++ b/FAQ.md @@ -71,7 +71,7 @@ It really depends on what image you're trying to change the colors of, where the ## How do I write new features? -There are a number of special-purpose scripting languages, as described in [docs](docs/). For more general features, you'll need to code directly in assembly language. See [docs/assembly_programming.md](docs/assembly_programming.md). Some of the [tutorials][tutorials] may also be helpful. +There are a number of special-purpose scripting languages, as described in [docs](docs/). For more general features, you'll need to code directly in [assembly language][asm]. Some of the [tutorials][tutorials] for specific features may also be helpful. ## I need more help! @@ -83,3 +83,4 @@ Try asking on IRC or Discord (see [README.md](README.md)). [polished-map]: https://github.com/Rangi42/polished-map [crowdmap]: https://github.com/yenatch/crowdmap/ [tutorials]: https://github.com/pret/pokecrystal/wiki/Tutorials +[asm]: https://github.com/pret/pokecrystal/wiki/Assembly-programming diff --git a/docs/assembly_programming.md b/docs/assembly_programming.md deleted file mode 100644 index 7bcaf6ea1..000000000 --- a/docs/assembly_programming.md +++ /dev/null @@ -1,25 +0,0 @@ -# Assembly Programming - -- [**RGBDS documentation**][rgbds-doc]: Includes information on the RGBDS tools and the assembly language syntax. - - [**GBZ80 instructions**][gbz80-instructions]: List of CPU instructions and their effects. - - [**RGBASM features**][rgbasm-features]: How to use the assembler features: constants, labels, sections, macros, etc. - - [**RGBLINK features**][rgblink-features]: How to use the linker, including the [pokecrystal.link](/pokecrystal.link) linkerscript. -- [**ASMSchool**][asmschool]: A gameboy assembly tutorial. -- [**GB ASM Tutorial**][gb-asm-tutorial]: A newer but still in-progress asm tutorial. -- [**Pan Docs**][pan-docs]: Everything You Always Wanted To Know About GAMEBOY (but were afraid to ask). -- [**GameBoy Programming Manual**][gb-manual]: The official GameBoy programming and hardware manual by Nintendo. -- [**GameBoy Opcode Summary**][gb-opcodes]: Describes the opcodes of GameBoy assembly language. -- [**GameBoy Memory Map**][gb-memory-map]: Describes the GameBoy Color address space. -- [**awesome-gbdev**][awesome-gbdev]: A curated list of Game Boy development resources such as tools, docs, emulators, related projects and open-source ROMs. - -[rgbds-doc]: https://rednex.github.io/rgbds/ -[rgbasm-features]: https://rednex.github.io/rgbds/rgbasm.5.html -[rgblink-features]: https://rednex.github.io/rgbds/rgblink.5.html -[gbz80-instructions]: https://rednex.github.io/rgbds/gbz80.7.html -[asmschool]: http://gameboy.mongenel.com/asmschool.html -[gb-asm-tutorial]: https://eldred.fr/gb-asm-tutorial/ -[pan-docs]: http://bgb.bircd.org/pandocs.htm -[gb-manual]: https://ia801906.us.archive.org/19/items/GameBoyProgManVer1.1/GameBoyProgManVer1.1.pdf -[gb-opcodes]: http://www.devrs.com/gb/files/opcodes.html -[gb-memory-map]: http://gameboy.mongenel.com/dmg/asmmemmap.html -[awesome-gbdev]: https://github.com/avivace/awesome-gbdev diff --git a/docs/bugs_and_glitches.md b/docs/bugs_and_glitches.md index 27156f980..f58d2a06b 100644 --- a/docs/bugs_and_glitches.md +++ b/docs/bugs_and_glitches.md @@ -10,6 +10,8 @@ Fixes are written in the `diff` format. If you've used Git before, this should l +add green + lines ``` +Some fixes are mentioned as breaking compatibility with link battles. This can be avoided by writing more complicated fixes that only apply if the value at `[wLinkMode]` is not `LINK_COLOSSEUM`. That's how Crystal itself fixed two bugs in Gold and Silver regarding the moves [Reflect and Light Screen](#reflect-and-light-screen-can-make-special-defense-wrap-around-above-1024) and [Present](#present-damage-is-incorrect-in-link-battles). + ## Contents @@ -898,23 +900,25 @@ CopyPokemonName_Buffer1_Buffer3: call Random cp 5 percent jr c, .CheckMagikarpArea - ; Try again if length >= 1616 mm (i.e. if LOW(length) >= 3 inches) + ; Try again if length >= 1616 mm (i.e. if LOW(length) >= 4 inches) ld a, [wMagikarpLength + 1] -- cp LOW(1616) ; should be "cp 3", since 1616 mm = 5'3", but LOW(1616) = 80 -+ cp 3 +- cp LOW(1616) ; should be "cp 4", since 1616 mm = 5'4", but LOW(1616) = 80 ++ cp 4 jr nc, .GenerateDVs ; 20% chance of skipping this check call Random cp 20 percent - 1 jr c, .CheckMagikarpArea - ; Try again if length >= 1600 mm (i.e. if LOW(length) >= 2 inches) + ; Try again if length >= 1600 mm (i.e. if LOW(length) >= 3 inches) ld a, [wMagikarpLength + 1] -- cp LOW(1600) ; should be "cp 2", since 1600 mm = 5'2", but LOW(1600) = 64 -+ cp 2 +- cp LOW(1600) ; should be "cp 3", since 1600 mm = 5'3", but LOW(1600) = 64 ++ cp 3 jr nc, .GenerateDVs ``` +**Better fix:** Rewrite the whole system to use millimeters instead of feet and inches, since they have better precision (1 in = 25.4 mm); and only convert from metric to imperial units for display purposes (or don't, of course). + ## Magikarp lengths can be miscalculated @@ -1205,22 +1209,22 @@ The exact cause of this bug is unknown. This is a mistake with the “`…`” tile in [gfx/battle/hp_exp_bar_border.png](/gfx/battle/hp_exp_bar_border.png): -![image](/docs/images/hp_exp_bar_border.png) +![image](/gfx/battle/hp_exp_bar_border.png) **Fix:** Lower the ellipsis by two pixels: -![image](/docs/images/hp_exp_bar_border_fix.png) +![image](/docs/images/hp_exp_bar_border.png) ## Two tiles in the `port` tileset are drawn incorrectly This is a mistake with the left-hand warp carpet corner tiles in [gfx/tilesets/port.png](/gfx/tilesets/port.png): -![image](/docs/images/port.png) +![image](/gfx/tilesets/port.png) **Fix:** Adjust them to match the right-hand corner tiles: -![image](/docs/images/port_fix.png) +![image](/docs/images/port.png) ## `LoadMetatiles` wraps around past 128 blocks diff --git a/docs/design_flaws.md b/docs/design_flaws.md index 80c34dfdb..97bfe20ac 100644 --- a/docs/design_flaws.md +++ b/docs/design_flaws.md @@ -8,6 +8,7 @@ These are parts of the code that do not work *incorrectly*, like [bugs and glitc - [Pic banks are offset by `PICS_FIX`](#pic-banks-are-offset-by-pics_fix) - [`PokemonPicPointers` and `UnownPicPointers` are assumed to start at the same address](#pokemonpicpointers-and-unownpicpointers-are-assumed-to-start-at-the-same-address) - [Footprints are split into top and bottom halves](#footprints-are-split-into-top-and-bottom-halves) +- [Music IDs $64 and $80 or above have special behavior](#music-ids-64-and-80-or-above-have-special-behavior) - [`ITEM_C3` and `ITEM_DC` break up the continuous sequence of TM items](#item_c3-and-item_dc-break-up-the-continuous-sequence-of-tm-items) - [Pokédex entry banks are derived from their species IDs](#pokédex-entry-banks-are-derived-from-their-species-ids) - [Identical sine wave code and data is repeated five times](#identical-sine-wave-code-and-data-is-repeated-five-times) @@ -73,7 +74,7 @@ GLOBAL PICS_FIX db BANK("Pics 24") ; BANK("Pics 1") + 23 ``` -**Fix:** Use `dba` instead of `dba_pic`, delete `FixPicBank`, and remove all four calls to `FixPicBank`. +**Fix:** Delete `FixPicBank` and remove all four calls to `FixPicBank` in [engine/gfx/load_pics.asm](/engine/gfx/load_pics.asm). Then use `dba` instead of `dba_pic` everywhere. ## `PokemonPicPointers` and `UnownPicPointers` are assumed to start at the same address @@ -148,9 +149,9 @@ And `GetMonBackpic`: **Fix:** -Don't enforce `org $4000` in pokecrystal.link. +Don't enforce `org $4000` in [pokecrystal.link](/pokecrystal.link). -Modify `GetFrontpicPointer`: +Edit `GetFrontpicPointer`: ```diff ld a, [wCurPartySpecies] @@ -269,7 +270,7 @@ INCBIN "gfx/footprints/wartortle.1bpp" ... ``` -Modify `Pokedex_LoadAnyFootprint`: +Edit `Pokedex_LoadAnyFootprint`: ```diff - push hl @@ -294,6 +295,132 @@ Modify `Pokedex_LoadAnyFootprint`: ``` +## Music IDs $64 and $80 or above have special behavior + +If a map's music ID in [data/maps/maps.asm](/master/data/maps/maps.asm) is $64 (the value of `MUSIC_MAHOGANY_MART` or `MUSIC_SUICUNE_BATTLE`) it will play either `MUSIC_ROCKET_HIDEOUT` or `MUSIC_CHERRYGROVE_CITY`. Moreover, if a map's music ID is $80 or above (the value of `RADIO_TOWER_MUSIC`) it might play `MUSIC_ROCKET_OVERTURE` or something else. + +This is caused by `GetMapMusic` in [home/map.asm](/master/home/map.asm): + +```asm +GetMapMusic:: + push hl + push bc + ld de, MAP_MUSIC + call GetMapField + ld a, c + cp MUSIC_MAHOGANY_MART + jr z, .mahoganymart + bit RADIO_TOWER_MUSIC_F, c + jr nz, .radiotower + farcall Function8b342 + ld e, c + ld d, 0 +.done + pop bc + pop hl + ret + +.radiotower + ld a, [wStatusFlags2] + bit STATUSFLAGS2_ROCKETS_IN_RADIO_TOWER_F, a + jr z, .clearedradiotower + ld de, MUSIC_ROCKET_OVERTURE + jr .done + +.clearedradiotower + ; the rest of the byte + ld a, c + and RADIO_TOWER_MUSIC - 1 + ld e, a + ld d, 0 + jr .done + +.mahoganymart + ld a, [wStatusFlags2] + bit STATUSFLAGS2_ROCKETS_IN_MAHOGANY_F, a + jr z, .clearedmahogany + ld de, MUSIC_ROCKET_HIDEOUT + jr .done + +.clearedmahogany + ld de, MUSIC_CHERRYGROVE_CITY + jr .done +``` + +**Fix:** + +Replace `RADIO_TOWER_MUSIC | MUSIC_GOLDENROD_CITY` with `MUSIC_RADIO_TOWER` in [data/maps/maps.asm](/master/data/maps/maps.asm). + +Redefine the special music constants in [constants/music_constants.asm](/master/constants/music_constants.asm): + +```diff +-; GetMapMusic picks music for this value (see home/map.asm) +-MUSIC_MAHOGANY_MART EQU $64 ++; GetMapMusic picks music for these values (see home/map.asm) ++MUSIC_MAHOGANY_MART EQU $fc ++MUSIC_RADIO_TOWER EQU $fd + + ; ExitPokegearRadio_HandleMusic uses these values + RESTART_MAP_MUSIC EQU $fe + ENTER_MAP_MUSIC EQU $ff +- +-; GetMapMusic picks music for this bit flag +-RADIO_TOWER_MUSIC_F EQU 7 +-RADIO_TOWER_MUSIC EQU 1 << RADIO_TOWER_MUSIC_F +``` + +And then edit `GetMapMusic`: + +```diff + GetMapMusic:: + push hl + push bc + ld de, MAP_MUSIC + call GetMapField + ld a, c + cp MUSIC_MAHOGANY_MART + jr z, .mahoganymart +- bit RADIO_TOWER_MUSIC_F, c +- jr nz, .radiotower ++ cp MUSIC_RADIO_TOWER ++ jr z, .radiotower + farcall Function8b342 + ld e, c + ld d, 0 + .done + pop bc + pop hl + ret + + .radiotower + ld a, [wStatusFlags2] + bit STATUSFLAGS2_ROCKETS_IN_RADIO_TOWER_F, a + jr z, .clearedradiotower + ld de, MUSIC_ROCKET_OVERTURE + jr .done + + .clearedradiotower +- ; the rest of the byte +- ld a, c +- and RADIO_TOWER_MUSIC - 1 +- ld e, a +- ld d, 0 ++ ld de, MUSIC_GOLDENROD_CITY + jr .done + + .mahoganymart + ld a, [wStatusFlags2] + bit STATUSFLAGS2_ROCKETS_IN_MAHOGANY_F, a + jr z, .clearedmahogany + ld de, MUSIC_ROCKET_HIDEOUT + jr .done + + .clearedmahogany + ld de, MUSIC_CHERRYGROVE_CITY + jr .done +``` + + ## `ITEM_C3` and `ITEM_DC` break up the continuous sequence of TM items [constants/item_constants.asm](/constants/item_constants.asm) defined the 50 TMs in order with `add_tm`, but `ITEM_C3` and `ITEM_DC` break up that sequence. @@ -352,11 +479,39 @@ GetNumberedTMHM: ret ``` +> There was originally a good reason for these two gaps! +> +> Pokémon traded from RBY to GSC have their catch rate interpreted as their new held item. This was planned early on in development, so some items were given indexes corresponding to appropriate Gen 1 catch rates: +> +> - $03 = 3: `BRIGHTPOWDER` is for Articuno, Zapdos, Moltres, and Mewtwo +> - $1E = 30: `LUCKY_PUNCH` is for Chansey +> - $23 = 35: `METAL_POWDER` is for Ditto +> - $3C = 60: `SILVER_LEAF` is for 10 Pokémon +> - $4B = 75: `GOLD_LEAF` is for 13 Pokémon +> - $96 = 150: `MYSTERYBERRY` is for Clefairy +> - $AA = 170: `POLKADOT_BOW` is for Jigglypuff +> - $B4 = 180: `BRICK_PIECE` is for Machop +> +> Yellow was also being developed then, and it did the reverse, altering some catch rates to correspond to appropriate Gen 2 items: +> +> - Starter Pikachu's catch rate became 163 = $A3 for `LIGHT_BALL` +> - Wild Kadabra's catch rate became 96 = $60 for `TWISTEDSPOON` +> - Wild Dragonair's catch rate became 27 = $1B for `PROTEIN` +> - Wild Dragonite's catch rate became 9 = $09 for `ANTIDOTE` +> +> Most catch rates were left as gaps in the item list, and transformed into held items via the `TimeCapsule_CatchRateItems` table in [data/items/catch_rate_items.asm](/data/items/catch_rate_items.asm). For example, the 52 Pokémon with catch rate 45 would hold the gap `ITEM_2D`, except that gets transformed into Bitter Berry. +> +> But a few Pokémon end up with weird items. Abra has a catch rate of 200, or $C8; and Krabby, Horsea, Goldeen, and Staryu have a catch rate of 225, or $E1. Those indexes correspond to the items TM09 Psych Up and TM33 Ice Punch, which seem like random choices—because they are. +> +> The TMs and HMs span from indexes $BF to $F9. However, as we can see in [pokegold-spaceworld](https://github.com/pret/pokegold-spaceworld/blob/master/constants/item_constants.asm), they *originally* spanned $C4 to $FF. For some reason they were shifted down by 5 during development. +> +> Before the index shift, the gap `ITEM_C3` would have been at index $C8, and `ITEM_DC` at $E1. In other words, they would have neatly corresponded to the catch rates for Abra, Krabby, Horsea, Goldeen, and Staryu! Then those Pokémon would have held Berries instead of random TMs. + **Fix:** Move `ITEM_C3` and `ITEM_DC` above all the TMs in every table of item data. -Modify engine/items/items.asm: +Edit [engine/items/items.asm](/engine/items/items.asm): ```diff GetTMHMNumber:: @@ -489,7 +644,7 @@ PokedexShow_GetDexEntryBank: db BANK("Pokedex Entries 193-251") ``` -**Fix:** Use `dba` instead of `dw` in `PokedexDataPointerTable`, and modify the code that accesses it to match. +**Fix:** Use `dba` instead of `dw` in `PokedexDataPointerTable`. Then edit [home.asm](/home.asm) to contain a single copy of the `PokedexDataPointerTable` lookup code, updated to work with 3-byte `dba` entries and get the bank from the first entry byte. Delete the three separate lookup routines and use the new one (placed in [home.asm](/home.asm) so it can be called from any bank.) ## Identical sine wave code and data is repeated five times diff --git a/docs/images/hp_exp_bar_border.png b/docs/images/hp_exp_bar_border.png index f0f5d31a6b012ef1cb5f9cfbecace2ef231a3d94..dd79d66363e77833667aa9a054408d71893d9fc7 100644 GIT binary patch delta 149 zcmXR}#yCNuo`a2nfnmRPjXRKHNq6*hWMJ6X&;2Kn7072S4sv&5Sa(k5C6E)~>Eak- zaXR@&KZ}HfM1X-}VHR`In?#AP2Liq@nA$d;%}KH5xaq!)eZ^DGB-@75er!pLCxp#Y zNYQhw47#LXIBntPkF5rVjZOi!OJ`;*U}Uf?$UGmz-&gbyXgGtXtDnm{r-UW|!nHFL delta 98 zcmZ3+STaE(hKT_PE_|@I0#eqVE{-7;w~~Jxt~v0}Uf@sSzyI?Y_1oo-Bqls#FP@QW z*KEO~aE_gA1CPDHzr=scPYetUZZI2qDDyBdJe9P05q70^J;*puS3j3^P6CZh7rjZ8_dHB$sSO)u3gV{jVM9D^i5s!%1w^S89m`8>H7Ju0CH+kOqzv|{%0)D%$-@Z$)esd4-tY6~`j2=FMG5+M9Y z;8D`?Ubq&#kAEbEcKlcZXrMF6w+Min$$-~28b!PyUSym1Y6K?u3CdjI#tp`+x2dz!NO|4extsHrXNoF2K?N zk_geTP;Q8);us)Ijk7VR@+)DWM*s_aY1SqrUDK$D;|l?pJ+%m+fgep4As|y~)AK#7 zah))*ssW}djt0=2ttkTFeY2_Kl?1>X#Iz3(k@z$LSZJ34pDl=G_?W4v zggNM#S$|$UW&?K;V1*Ni+AKnV7vCqcSmsr0s!Ur9I$B*bfCNBQXo1hp$r1pC<68*u z771k+tEpJaGer`}NmMt15kOWCSrmXo#2P{-3P6q6AwZ`X?h5!gYo`1EJSwu&36BUw` zz`ub17^ijBun-P^$B@VhA9oNS(xx>jU0(RevW+{ykB<4fUk7ywgts1n_`gxyh_Ojb&CfaI9vUmEgZac5usU;h6F^I{Fh?^IhIu5z0u~bt>$`IAECG-NEdp5J zPXah`z9qe^@Ko^`7|}8$m>|GP5>NtUR0>v~t{^}pM_-*!wo;f$6<0{$VbUf5tAE=^ z7}tFuv`PRApeX`$NHF0uM4jK_{0?f@qY{mM{#Ot{1E}f)FalJgi>g-iNYKrVm;}(A zot2rkE&(*aCJ9j8^r`T%8}iZUZ4!WLjNJif!tdzX_-f7~dhbYvv%L1z1Yq7dv*8_$ z(Io-fZs_n#+kY#hoFc%48PLkn173Eji%0{X6`MMFis!l2qDPhhlQwLU09H5B zlt#&zn@qn!$7gvVKs51F@&0!aph5z#8THBr(@4KTg#chlOSZmUsfSNwu{zBh8Bii`-MI1?e==zTWb2qr=T=zmIj36hWAqIipFo6A z&fj`8>=T}=o6g!r3BVpIjcL4pck}j7#eB-0000a(X z*ecQ%ZJzoEC_a=ClC&Y1uG=}Db7yvm^}@2d_x{eAbI;rvAb(PQ@e$%N^*GsC$3~6cBR?#$IrcUBIDHl2g)6B z=xiJD{3fOP_kRL<6au`QZOXxtQoZ{ZdY=JUSX5C4#b6x=J+*&FsS%}mj<$X#+nmJZ zWdW%+cL`!Rxa?*x#MOCvH1pnrXJwm{c=oJ-9F&(p+k%_Z=U+)142HB~d>`3z%gM*(weXEE#D?n~md%5o~24=&5ONQ?FQ1<}9zD5Su`T|n! zzE70Gl}Y@n2cwaXAvDIt;Tzu({TDbjO=i@bZ5V&+=xqQ2udZM|465o9`BKDB^eepo z;@d9`Uw;gNc1+y1ujdKnm&2f~>xGWtFB$0jE7M`zdPN^0&F8d6)C;fA9RKC?ZQUav zipyLr9-+q!wgt5G&zw8`Td8Lf?(@}KB(CZ)*!eI5UG2$lE=-kr`nF3P{7~Zj3IiGI z0usz*X_w>ibJ=7%T1pdgMUcL`85lrh;ama0PJcUf;D>L2R`ZracYhIEc_kT>HZX{pX9zaTfS5yDyeS6Rf%-EQ zK4ElP{4s$>`&$Dz*-A9Q@tp@(FWuP!VK~PD% JPDHLkV1lV0?b!eT diff --git a/docs/images/port_fix.png b/docs/images/port_fix.png deleted file mode 100644 index 45fa26338846e113230333d112bee30b6b59d4d1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1526 zcmVPx)ph-kQRCwC$Tnnz+Fc8coxg?itMb)5XnEkIE=qpl$ z-or_3&+LDbu5->s`<8R_#@+At)N!6?eIDc3zU(;U{+LIG z02bKtH+kOqzv|{%0)D%$-@Z$)e zsd4-tY6~`j2=FMG5+M9Y;8D`?Ubq&#k0gb5{8$2Lpfkz02!NZ(fY*G0b772x@}5%d zOQ2AjF%4ijcK->W*k6<=j{uTH2s|#rBS6H&SPtvA6Tpi=mJz^G{Tcx@m8_}Q$i`?+ zoFog=EI2-E0@!@J(z@aZ5x{bUECNKrK`&hCZj1y^{*4QjW&y$Ogn=@Qvjjx@?h?Qg zEc^}cduTS_Q)<)mJ*;t^FtDltrc6LY;==^69IK87(44I)0^ohKspFLdz#PQ14-k>~ zGyzy>mjRzGh-LVgsi=fG=$KhvJZ1xT5@3ZBh}tYdfEV8SW7ptjQ%QHn1$VpT;fe}Df4_Op|M8q0GCJI1}*dait7~~Pa zO0I?h5!gY zo`1EJSwu&36BUw`z`ub17^ijBun-P^$B@VhA9oNS(xx>jU0(RevW+{ykB<4fUk7y< zSaO9`|1<(v5*j4{>lI)G@PJ>r$*et%WmYwCtY(^(;J;{qsCSH^2ZF%LrdF@tBmu4j zUt25A*#oH4R2$WNr1o*B$rP>Ff)M~Cz_}m<(<1=0u@km^TEeWHe}w?uj_MWx7|5(~ z0xMXUduNl65J0Qdv-3NWi)L#Y{0;$D+kIC9R4+OOP*uXMC}1kg>za-xK<525A1iUc z_Zwj0M!V=_j2pd11YFkSQ6&}bPi37e3DEU(LIkinb9WO!OR_LWGZKb*B*Ow06AbIS za_=kwkOVCPSl~|rIB~uuy{zz5@fjG=G9;KFz)BKO0%TMQR-djQKqNm`N2^ zNZ?`8CIGA3M;OCm z^hnUnjhF<`oSl`Kwk`oQz$OV$-SnyOu^aNy=xq{!YK+|hXu|L4+W2bDB6{yghO@l( z)dXPPIkVv%jnO3m+vJ^1B;9_4j_}8*?vCyuubgbnv9f<}FUZ(Q0Or_y z0s*WI?xv?b-=GRUd(S~>Zs_n#+kY#hoFc%48PLkn173Eji%0{X6`MMFis!l2qDPhh zlQwLU09H5Blt#&zn@qn!$7gvVKs51F@&0!aph5z#8THBr(@4KTg#cG z8EsP~fcCV|iibxgNYI)~w!U4dhfid&I?WszP$F;Lxbhf(GHC*2>zGXER#@&ir&{l0 z^bH)JK!i}v-+DCc6P~M^&e}x@z#b}%ynlG==)UBsV|xBv{}Tw1jRZ2+^uTA2xb2eo zu{V7+?tkohjM-XTMH>WT+^|+yz1bS@naA^|@BfksWF**W0;-)nnH+rP^)D+3(b?OH cIk9{H1_U>#%_= 1616 mm (i.e. if LOW(length) >= 3 inches) +; Try again if length >= 1616 mm (i.e. if LOW(length) >= 4 inches) ld a, [wMagikarpLength + 1] - cp LOW(1616) ; should be "cp 3", since 1616 mm = 5'3", but LOW(1616) = 80 + cp LOW(1616) ; should be "cp 4", since 1616 mm = 5'4", but LOW(1616) = 80 jr nc, .GenerateDVs ; 20% chance of skipping this check call Random cp 20 percent - 1 jr c, .CheckMagikarpArea -; Try again if length >= 1600 mm (i.e. if LOW(length) >= 2 inches) +; Try again if length >= 1600 mm (i.e. if LOW(length) >= 3 inches) ld a, [wMagikarpLength + 1] - cp LOW(1600) ; should be "cp 2", since 1600 mm = 5'2", but LOW(1600) = 64 + cp LOW(1600) ; should be "cp 3", since 1600 mm = 5'3", but LOW(1600) = 64 jr nc, .GenerateDVs .CheckMagikarpArea: