summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRangi <remy.oukaour+rangi42@gmail.com>2020-07-10 20:12:38 -0400
committerRangi <remy.oukaour+rangi42@gmail.com>2020-07-13 10:59:22 -0400
commit4eeab8973c8367b3ae8885d158197392489e6174 (patch)
tree4734c3387645630e3092ef858b2433159a8abdf6
parent30c327276c937e06e3c8b7990cb9029937739f8e (diff)
Disassemble the final English debug ROMs
-rw-r--r--Makefile39
-rw-r--r--README.md2
-rw-r--r--constants/item_data_constants.asm2
-rw-r--r--constants/misc_constants.asm3
-rw-r--r--data/stadium/stadium_gold_debug.bin1
-rw-r--r--data/stadium/stadium_silver_debug.bin2
-rw-r--r--engine/debug/color_picker.asm (renamed from engine/menus/debug.asm)2
-rw-r--r--engine/debug/debug_room.asm1391
-rw-r--r--engine/items/items.asm10
-rw-r--r--engine/items/mart.asm2
-rw-r--r--engine/items/switch_items.asm10
-rw-r--r--engine/menus/intro_menu.asm6
-rw-r--r--engine/menus/main_menu.asm23
-rw-r--r--engine/rtc/rtc.asm10
-rw-r--r--home/map.asm2
-rw-r--r--hram.asm8
-rw-r--r--layout.link2
-rw-r--r--main.asm13
-rw-r--r--roms.sha12
-rw-r--r--sram.asm9
-rw-r--r--wram.asm40
21 files changed, 1542 insertions, 37 deletions
diff --git a/Makefile b/Makefile
index faff2d33..c6774a88 100644
--- a/Makefile
+++ b/Makefile
@@ -1,4 +1,4 @@
-roms := pokegold.gbc pokesilver.gbc
+roms := pokegold.gbc pokesilver.gbc pokegold_debug.gbc pokesilver_debug.gbc
rom_obj := \
audio.o \
@@ -21,9 +21,13 @@ gfx/pics
gold_excl_obj := $(addsuffix _gold.o,$(gs_excl_asm))
silver_excl_obj := $(addsuffix _silver.o,$(gs_excl_asm))
+gold_debug_excl_obj := $(addsuffix _gold_debug.o,$(gs_excl_asm))
+silver_debug_excl_obj := $(addsuffix _silver_debug.o,$(gs_excl_asm))
pokegold_obj := $(rom_obj:.o=_gold.o) $(gold_excl_obj)
pokesilver_obj := $(rom_obj:.o=_silver.o) $(silver_excl_obj)
+pokegold_debug_obj := $(rom_obj:.o=_gold_debug.o) $(gold_debug_excl_obj)
+pokesilver_debug_obj := $(rom_obj:.o=_silver_debug.o) $(silver_debug_excl_obj)
### Build tools
@@ -50,16 +54,18 @@ RGBLINK ?= $(RGBDS)rgblink
.SECONDARY:
all: $(roms)
-gold: pokegold.gbc
-silver: pokesilver.gbc
+gold: pokegold.gbc
+silver: pokesilver.gbc
+gold_debug: pokegold_debug.gbc
+silver_debug: pokesilver_debug.gbc
clean:
- rm -f $(roms) $(pokegold_obj) $(pokesilver_obj) $(roms:.gbc=.map) $(roms:.gbc=.sym) rgbdscheck.o
+ rm -f $(roms) $(pokegold_obj) $(pokesilver_obj) $(pokegold_debug_obj) $(pokesilver_debug_obj) $(roms:.gbc=.map) $(roms:.gbc=.sym) rgbdscheck.o
find gfx \( -name "*.[12]bpp" -o -name "*.lz" -o -name "*.gbcpal" -o -name "*.dimensions" -o -name "*.sgb.tilemap" \) -delete
$(MAKE) clean -C tools/
tidy:
- rm -f $(roms) $(pokegold_obj) $(pokesilver_obj) $(roms:.gbc=.map) $(roms:.gbc=.sym) rgbdscheck.o
+ rm -f $(roms) $(pokegold_obj) $(pokesilver_obj) $(pokegold_debug_obj) $(pokesilver_debug_obj) $(roms:.gbc=.map) $(roms:.gbc=.sym) rgbdscheck.o
$(MAKE) clean -C tools/
compare: $(roms)
@@ -75,8 +81,10 @@ ifeq ($(DEBUG),1)
RGBASMFLAGS += -E
endif
-$(pokegold_obj): RGBASMFLAGS += -D _GOLD
-$(pokesilver_obj): RGBASMFLAGS += -D _SILVER
+$(pokegold_obj): RGBASMFLAGS += -D _GOLD
+$(pokesilver_obj): RGBASMFLAGS += -D _SILVER
+$(pokegold_debug_obj): RGBASMFLAGS += -D _GOLD -D _DEBUG
+$(pokesilver_debug_obj): RGBASMFLAGS += -D _SILVER -D _DEBUG
rgbdscheck.o: rgbdscheck.asm
$(RGBASM) -o $@ $<
@@ -100,15 +108,26 @@ $(foreach obj, $(filter-out $(gold_excl_obj), $(pokegold_obj)), \
$(eval $(call DEP,$(obj),$(obj:_gold.o=.asm))))
$(foreach obj, $(filter-out $(silver_excl_obj), $(pokesilver_obj)), \
$(eval $(call DEP,$(obj),$(obj:_silver.o=.asm))))
+$(foreach obj, $(filter-out $(gold_debug_excl_obj), $(pokegold_debug_obj)), \
+ $(eval $(call DEP,$(obj),$(obj:_gold_debug.o=.asm))))
+$(foreach obj, $(filter-out $(silver_debug_excl_obj), $(pokesilver_debug_obj)), \
+ $(eval $(call DEP,$(obj),$(obj:_silver_debug.o=.asm))))
# Dependencies for game-exclusive objects (keep _gold and _silver in asm file basenames)
-$(foreach obj, $(gold_excl_obj) $(silver_excl_obj), $(eval $(call DEP,$(obj),$(obj:.o=.asm))))
+$(foreach obj, $(gold_excl_obj) $(silver_excl_obj), \
+ $(eval $(call DEP,$(obj),$(obj:.o=.asm))))
+$(foreach obj, $(gold_debug_excl_obj), \
+ $(eval $(call DEP,$(obj),$(obj:_gold_debug.o=_gold.asm))))
+$(foreach obj, $(silver_debug_excl_obj), \
+ $(eval $(call DEP,$(obj),$(obj:_silver_debug.o=_silver.asm))))
endif
-pokegold_opt = -cjsv -t POKEMON_GLD -i AAUE -k 01 -l 0x33 -m 0x10 -r 3 -p 0
-pokesilver_opt = -cjsv -t POKEMON_SLV -i AAXE -k 01 -l 0x33 -m 0x10 -r 3 -p 0
+pokegold_opt = -cjsv -t POKEMON_GLD -i AAUE -k 01 -l 0x33 -m 0x10 -r 3 -p 0
+pokesilver_opt = -cjsv -t POKEMON_SLV -i AAXE -k 01 -l 0x33 -m 0x10 -r 3 -p 0
+pokegold_debug_opt = -cjsv -t POKEMON_GLD -i AAUE -k 01 -l 0x33 -m 0x10 -r 3 -p 0
+pokesilver_debug_opt = -cjsv -t POKEMON_SLV -i AAXE -k 01 -l 0x33 -m 0x10 -r 3 -p 0
%.gbc: $$(%_obj) layout.link
$(RGBLINK) -n $*.sym -m $*.map -l layout.link -o $@ $(filter %.o,$^)
diff --git a/README.md b/README.md
index 6be9726d..3415c580 100644
--- a/README.md
+++ b/README.md
@@ -6,6 +6,8 @@ It builds the following ROMs:
- Pokemon - Gold Version (UE) [C][!].gbc `sha1: d8b8a3600a465308c9953dfa04f0081c05bdcb94`
- Pokemon - Silver Version (UE) [C][!].gbc `sha1: 49b163f7e57702bc939d642a18f591de55d92dae`
+- mons2_gld_ps3_debug.bin `sha1: 53783c57378122805c5b4859d19e1a224f02a1ed`
+- mons2_slv_ps3_debug.bin `sha1: 4c2fafebdbc7551f4cd3f348bdd17e420b93b6e7`
To set up the repository, see [INSTALL.md](INSTALL.md).
diff --git a/constants/item_data_constants.asm b/constants/item_data_constants.asm
index 4c295d5b..f6d6384c 100644
--- a/constants/item_data_constants.asm
+++ b/constants/item_data_constants.asm
@@ -47,6 +47,8 @@ MAX_BALLS EQU 12
MAX_KEY_ITEMS EQU 25
MAX_PC_ITEMS EQU 50
+MAX_ITEM_STACK EQU 99
+
; mail
MAIL_LINE_LENGTH EQU $10
MAIL_MSG_LENGTH EQU $20
diff --git a/constants/misc_constants.asm b/constants/misc_constants.asm
index 9efd3c55..ca9bc937 100644
--- a/constants/misc_constants.asm
+++ b/constants/misc_constants.asm
@@ -23,6 +23,9 @@ ENDC
SAVE_CHECK_VALUE_1 EQU 99
SAVE_CHECK_VALUE_2 EQU 127
+; RTC halted check value
+RTC_HALT_VALUE EQU $1234
+
; time of day boundaries
MORN_HOUR EQU 4 ; 4 AM
DAY_HOUR EQU 10 ; 10 AM
diff --git a/data/stadium/stadium_gold_debug.bin b/data/stadium/stadium_gold_debug.bin
new file mode 100644
index 00000000..665a5fcc
--- /dev/null
+++ b/data/stadium/stadium_gold_debug.bin
@@ -0,0 +1 @@
+N64PS3JZnkl,5]BuQ1P`5Ѷ*LP&gER^]@jtYiK8SXXxD|.*œ634V_U-N7KeR1ܦz,^CK{{muŨbqG6_W*Y'.E)gyyYjiu%HKmB>Aa0ѥ扟&#\Rյ&U+y:;$i-C)=>Xʷi*=e/lYiAI_7by\j<^ar}ik쵩1rh:ДmԮ>7ᅂ|6UJ \ No newline at end of file
diff --git a/data/stadium/stadium_silver_debug.bin b/data/stadium/stadium_silver_debug.bin
new file mode 100644
index 00000000..cd1d857f
--- /dev/null
+++ b/data/stadium/stadium_silver_debug.bin
@@ -0,0 +1,2 @@
+N64PS3ZR|<v-P1(`5Ѷ*LP&gE2^]@jtYi8PSX4C.h#V66Q2)whd˘%
+嗫eQ<p`$(z,^CmK{muŨbG6_W*U'.C)gyyK?}%HKmB>Aa0ѥ扟&#\Rյ&U+y:;$i-C)=>Xʷi*=e/lYiAI_7by\j<^ar}ik쵩1rh"{Ԯ>7ᅂ|7S \ No newline at end of file
diff --git a/engine/menus/debug.asm b/engine/debug/color_picker.asm
index 0df9ea3f..204703d9 100644
--- a/engine/menus/debug.asm
+++ b/engine/debug/color_picker.asm
@@ -1,5 +1,3 @@
-; Left-over debug code from pokegold-debug
-
const_def $6a
const DEBUGTEST_TICKS_1 ; $6a
const DEBUGTEST_TICKS_2 ; $6b
diff --git a/engine/debug/debug_room.asm b/engine/debug/debug_room.asm
new file mode 100644
index 00000000..12259ce9
--- /dev/null
+++ b/engine/debug/debug_room.asm
@@ -0,0 +1,1391 @@
+ ; _DebugRoom.MenuItems indexes
+ const_def
+ const DEBUGROOMMENU_PAGE_1 ; 0
+ const DEBUGROOMMENU_PAGE_2 ; 1
+DEBUGROOMMENU_NUM_PAGES EQU const_value
+
+ ; _DebugRoom.Strings and _DebugRoom.Jumptable indexes
+ const_def
+ const DEBUGROOMMENUITEM_SP_CLEAR ; 0
+ const DEBUGROOMMENUITEM_WIN_WORK_CLR ; 1
+ const DEBUGROOMMENUITEM_POKEMON_GET ; 2
+ const DEBUGROOMMENUITEM_POKEDEX_COMP ; 3
+ const DEBUGROOMMENUITEM_TIMER_RESET ; 4
+ const DEBUGROOMMENUITEM_DECORATE_ALL ; 5
+ const DEBUGROOMMENUITEM_ITEM_GET ; 6
+ const DEBUGROOMMENUITEM_RTC_EDIT ; 7
+ const DEBUGROOMMENUITEM_NEXT ; 8
+ const DEBUGROOMMENUITEM_GB_ID_SET ; 9
+ const DEBUGROOMMENUITEM_BTL_REC_CLR ; a
+ const DEBUGROOMMENUITEM_POKEDEX_CLR ; b
+ const DEBUGROOMMENUITEM_HALT_CHK_CLR ; c
+
+_DebugRoom:
+ ldh a, [hJoyDown]
+ and SELECT | START
+ cp SELECT | START
+ ret nz
+ ldh a, [hDebugRoomMenuPage]
+ push af
+ xor a
+ ldh [hDebugRoomMenuPage], a
+.loop
+ ld hl, wTilemap
+ ld bc, wTilemapEnd - wTilemap
+ ld a, " "
+ call ByteFill
+ call DebugRoom_PrintStackBottomTop
+ call DebugRoom_PrintWindowStackBottomTop
+ call DebugRoom_PrintRTCHaltChk
+ ldh a, [hDebugRoomMenuPage]
+ ld [wWhichIndexSet], a
+ ld hl, .MenuHeader
+ call LoadMenuHeader
+ call SetUpMenu
+.wait
+ call GetScrollingMenuJoypad
+ ld a, [wMenuJoypad]
+ and A_BUTTON | B_BUTTON
+ jr z, .wait
+ call CloseWindow
+ cp B_BUTTON
+ jr z, .done
+ ld a, [wMenuSelection]
+ ld hl, .Jumptable
+ rst JumpTable
+ jr .loop
+.done
+ pop af
+ ldh [hDebugRoomMenuPage], a
+ ret
+
+.MenuHeader:
+ db MENU_BACKUP_TILES ; flags
+ menu_coords 0, 0, 15, SCREEN_HEIGHT - 1
+ dw .MenuData
+ db 1 ; default option
+
+.MenuData:
+ db STATICMENU_CURSOR ; flags
+ db 0 ; items
+ dw .MenuItems
+ dw PlaceMenuStrings
+ dw .Strings
+
+.Strings:
+; entries correspond to DEBUGROOMMENUITEM_* constants
+ db "SP CLEAR@"
+ db "WIN WORK CLR@"
+ db "#MON GET!@"
+ db "#DEX COMP@"
+ db "TIMER RESET@"
+ db "DECORATE ALL@"
+ db "ITEM GET!@"
+ db "RTC EDIT@"
+ db "NEXT@"
+ db "GB ID SET@"
+ db "BTL REC CLR@"
+ db "#DEX CLR@"
+ db "HALT CHK CLR@"
+
+.Jumptable:
+; entries correspond to DEBUGROOMMENUITEM_* constants
+ dw DebugRoomMenu_SpClear
+ dw DebugRoomMenu_WinWorkClr
+ dw DebugRoomMenu_PokemonGet
+ dw DebugRoomMenu_PokedexComp
+ dw DebugRoomMenu_TimerReset
+ dw DebugRoomMenu_DecorateAll
+ dw DebugRoomMenu_ItemGet
+ dw DebugRoomMenu_RTCEdit
+ dw DebugRoomMenu_Next
+ dw DebugRoomMenu_GBIDSet
+ dw DebugRoomMenu_BtlRecClr
+ dw DebugRoomMenu_PokedexClr
+ dw DebugRoomMenu_HaltChkClr
+
+.MenuItems:
+; entries correspond to DEBUGROOMMENU_* constants
+
+ ; DEBUGROOMMENU_PAGE_1
+ db 8
+ db DEBUGROOMMENUITEM_SP_CLEAR
+ db DEBUGROOMMENUITEM_WIN_WORK_CLR
+ db DEBUGROOMMENUITEM_RTC_EDIT
+ db DEBUGROOMMENUITEM_TIMER_RESET
+ db DEBUGROOMMENUITEM_HALT_CHK_CLR
+ db DEBUGROOMMENUITEM_GB_ID_SET
+ db DEBUGROOMMENUITEM_BTL_REC_CLR
+ db DEBUGROOMMENUITEM_NEXT
+ db -1
+
+ ; DEBUGROOMMENU_PAGE_2
+ db 6
+ db DEBUGROOMMENUITEM_POKEMON_GET
+ db DEBUGROOMMENUITEM_ITEM_GET
+ db DEBUGROOMMENUITEM_POKEDEX_COMP
+ db DEBUGROOMMENUITEM_POKEDEX_CLR
+ db DEBUGROOMMENUITEM_DECORATE_ALL
+ db DEBUGROOMMENUITEM_NEXT
+ db -1
+
+DebugRoomMenu_Next:
+ ldh a, [hDebugRoomMenuPage]
+ inc a
+ cp DEBUGROOMMENU_NUM_PAGES
+ jr c, .got_page
+ xor a ; DEBUGROOMMENU_PAGE_1
+.got_page
+ ldh [hDebugRoomMenuPage], a
+ ret
+
+DebugRoom_SaveChecksum:
+ ld a, BANK(sGameData)
+ call OpenSRAM
+ ld bc, sGameDataEnd - sGameData
+ ld de, 0
+ ld hl, sGameData
+.loop
+ ld a, [hli]
+ add e
+ ld e, a
+ ld a, d
+ adc 0
+ ld d, a
+ dec bc
+ ld a, b
+ or c
+ jr nz, .loop
+ ld a, e
+ ld [sChecksum + 0], a
+ ld a, d
+ ld [sChecksum + 1], a
+ call CloseSRAM
+ ret
+
+DebugRoomMenu_SpClear:
+ call YesNoBox
+ ret c
+ ld a, BANK(sStackTop)
+ call OpenSRAM
+ xor a
+ ld hl, sStackTop
+ ld [hli], a
+ ld [hl], a
+ call CloseSRAM
+ call DebugRoom_PrintStackBottomTop
+ ret
+
+DebugRoom_PrintStackBottomTop:
+ ld a, BANK(sStackTop)
+ call OpenSRAM
+ hlcoord 16, 13
+ ld de, sStackTop + 1
+ ld c, 1
+ call PrintHexNumber
+ ld de, sStackTop + 0
+ ld c, 1
+ call PrintHexNumber
+ call CloseSRAM
+ hlcoord 16, 11
+ ld de, .SPString
+ call PlaceString
+ ld d, LOW(wStackBottom)
+ ld e, HIGH(wStackBottom)
+ push de
+ ld hl, sp+0
+ ld d, h
+ ld e, l
+ hlcoord 16, 12
+ ld c, 2
+ call PrintHexNumber
+ pop de
+ ret
+
+.SPString:
+ db "SP:@"
+
+DebugRoomMenu_WinWorkClr:
+ call YesNoBox
+ ret c
+ ld a, [wWindowStackPointer]
+ ld l, a
+ ld a, [wWindowStackPointer + 1]
+ ld h, a
+ inc hl
+ ld a, l
+ sub LOW(sWindowStackBottom)
+ ld a, h
+ sbc HIGH(sWindowStackBottom)
+ ret c
+ ld a, BANK(sWindowStackBottom)
+ call OpenSRAM
+ ld bc, -sWindowStackBottom + $10000
+ add hl, bc
+ ld b, h
+ ld c, l
+ ld hl, sWindowStackBottom
+ xor a
+ call ByteFill
+ call CloseSRAM
+ ret
+
+DebugRoom_PrintWindowStackBottomTop:
+ ld a, BANK(sWindowStackBottom)
+ call OpenSRAM
+ ld hl, sWindowStackBottom
+.loop
+ ld a, h
+ cp HIGH(sWindowStackTop) + 1
+ jr z, .ok
+ ld a, [hl]
+ or a
+ jr nz, .ok
+ inc hl
+ jr .loop
+.ok
+ call CloseSRAM
+ ld a, h
+ ld h, l
+ ld l, a
+ push hl
+ ld hl, sp+0
+ ld d, h
+ ld e, l
+ hlcoord 16, 17
+ ld c, 2
+ call PrintHexNumber
+ pop hl
+ ld d, LOW(sWindowStackBottom)
+ ld e, HIGH(sWindowStackBottom)
+ push de
+ ld hl, sp+0
+ ld d, h
+ ld e, l
+ hlcoord 16, 16
+ ld c, 2
+ call PrintHexNumber
+ pop de
+ hlcoord 16, 15
+ ld de, .WSPString
+ call PlaceString
+ ret
+
+.WSPString:
+ db "WSP:@"
+
+DebugRoomMenu_PokedexComp:
+ call YesNoBox
+ ret c
+ ld a, BANK(sGameData) ; aka BANK(sPlayerData3)
+ call OpenSRAM
+ ld hl, sPlayerData3 + (wPokedexCaught - wPlayerData3)
+ ld b, wEndPokedexSeen - wPokedexCaught
+ ld a, %11111111
+.loop1
+ ld [hli], a
+ dec b
+ jr nz, .loop1
+ ld a, (1 << (NUM_POKEMON % 8)) - 1 ; %00000111
+ ld [sPlayerData3 + (wEndPokedexCaught - 1 - wPlayerData3)], a
+ ld [sPlayerData3 + (wEndPokedexSeen - 1 - wPlayerData3)], a
+ ld hl, sPlayerData3 + (wStatusFlags - wPlayerData3)
+ set STATUSFLAGS_UNOWN_DEX_F, [hl]
+ ld a, UNOWN_A
+ ld [sGameData + (wFirstUnownSeen - wGameData)], a
+ ld hl, sGameData + (wUnownDex - wGameData)
+ ld b, NUM_UNOWN
+.loop2
+ ld [hli], a
+ inc a
+ dec b
+ jr nz, .loop2
+ call CloseSRAM
+ call DebugRoom_SaveChecksum
+ ret
+
+DebugRoomMenu_PokedexClr:
+ call YesNoBox
+ ret c
+ ld a, BANK(sPlayerData3)
+ call OpenSRAM
+ ld hl, sPlayerData3 + (wStatusFlags - wPlayerData3)
+ res STATUSFLAGS_UNOWN_DEX_F, [hl]
+ ld hl, sPlayerData3 + (wPokedexCaught - wPlayerData3)
+ ld bc, wEndPokedexSeen - wPokedexCaught
+ xor a
+ call ByteFill
+ ld hl, sGameData + (wUnownDex - wGameData)
+ ld bc, NUM_UNOWN
+ xor a
+ call ByteFill
+ call CloseSRAM
+ call DebugRoom_SaveChecksum
+ ret
+
+DebugRoomMenu_TimerReset:
+ call YesNoBox
+ ret c
+ ld a, BANK(sRTCStatusFlags)
+ call OpenSRAM
+ ld hl, sRTCStatusFlags
+ set 7, [hl]
+ call CloseSRAM
+ ret
+
+DebugRoomMenu_DecorateAll:
+ call YesNoBox
+ ret c
+ ld a, BANK(sPlayerData3)
+ call OpenSRAM
+ ld hl, sPlayerData3 + (wEventFlags - wPlayerData3)
+ ld de, EVENT_DECO_BED_1 ; the first EVENT_DECO_* constant
+ ld b, SET_FLAG
+ ld c, EVENT_DECO_BIG_LAPRAS_DOLL - EVENT_DECO_BED_1 + 1
+.loop
+ push bc
+ push de
+ push hl
+ call FlagAction
+ pop hl
+ pop de
+ pop bc
+ inc de
+ dec c
+ jr nz, .loop
+ call CloseSRAM
+ call DebugRoom_SaveChecksum
+ ret
+
+paged_value: MACRO
+ dw \1 ; value address
+ db \2 ; min value
+ db \3 ; max value
+ db \4 ; initial value
+ dw \5 ; label string
+ dw \6 ; value name function
+ db \7 ; is hex value?
+ENDM
+
+PAGED_VALUE_SIZE EQU 10
+
+DebugRoom_EditPagedValues:
+ xor a
+ ld [wDebugRoomCurPage], a
+ ld [wDebugRoomCurValue], a
+ ld a, [hli]
+ ld [wDebugRoomAFunction], a
+ ld a, [hli]
+ ld [wDebugRoomAFunction+1], a
+ ld a, [hli]
+ ld [wDebugRoomSelectFunction], a
+ ld a, [hli]
+ ld [wDebugRoomSelectFunction+1], a
+ ld a, [hli]
+ ld [wDebugRoomStartFunction], a
+ ld a, [hli]
+ ld [wDebugRoomStartFunction+1], a
+ ld a, [hli]
+ ld [wDebugRoomAutoFunction], a
+ ld a, [hli]
+ ld [wDebugRoomAutoFunction+1], a
+ ld a, [hli]
+ ld [wDebugRoomPageCount], a
+ ld a, l
+ ld [wDebugRoomPagedValuesPtr], a
+ ld a, h
+ ld [wDebugRoomPagedValuesPtr+1], a
+ ld hl, hInMenu
+ ld a, [hl]
+ push af
+ ld [hl], TRUE
+ call ClearBGPalettes
+ hlcoord 0, 0
+ ld b, SCREEN_HEIGHT - 2
+ ld c, SCREEN_WIDTH - 2
+ call Textbox
+ hlcoord 8, 17
+ ld de, DebugRoom_PageString
+ call PlaceString
+ call DebugRoom_InitializePagedValues
+ xor a
+ call DebugRoom_PrintPage
+ ld a, "▶"
+ call DebugRoom_ShowHideCursor
+ xor a
+ ldh [hJoyLast], a
+ xor a
+ ld [wDebugRoomCurPage], a
+ inc a
+ ldh [hBGMapMode], a
+ call WaitBGMap
+ ld b, SCGB_DIPLOMA
+ call GetSGBLayout
+ call SetPalettes
+.resume
+ call DelayFrame
+ call JoyTextDelay
+ ldh a, [hJoyLast]
+ bit 1, a
+ jr nz, .done
+ ld hl, .continue
+ push hl
+ rra ; A_BUTTON_F?
+ jr c, DebugRoom_PagedValuePressedA
+ rra ; skip B_BUTTON_F
+ rra ; SELECT_F?
+ jr c, DebugRoom_PagedValuePressedSelect
+ rra ; START_F?
+ jr c, DebugRoom_PagedValuePressedStart
+ rra ; D_RIGHT_F?
+ jp c, DebugRoom_IncrementPagedValue
+ rra ; D_LEFT_F?
+ jp c, DebugRoom_DecrementPagedValue
+ rra ; D_UP_F?
+ jp c, DebugRoom_PrevPagedValue
+ rra ; D_DOWN_F?
+ jp c, DebugRoom_NextPagedValue
+ pop hl
+.continue
+; call wDebugRoomAutoFunction if it's not null, then jump to .resume
+ ld hl, .resume
+ push hl
+ ld a, [wDebugRoomAutoFunction]
+ ld l, a
+ ld a, [wDebugRoomAutoFunction+1]
+ ld h, a
+ or l
+ ret z
+ jp hl
+
+.done
+ pop af
+ ldh [hInMenu], a
+ scf
+ ret
+
+DebugRoom_PagedValuePressedA:
+ ld hl, wDebugRoomAFunction
+ jr _CallNonNullPointer
+
+DebugRoom_PagedValuePressedSelect:
+ ld hl, wDebugRoomSelectFunction
+ jr _CallNonNullPointer
+
+DebugRoom_PagedValuePressedStart:
+ ld hl, wDebugRoomStartFunction
+ ; fallthrough
+
+_CallNonNullPointer:
+ ld a, [hli]
+ ld h, [hl]
+ ld l, a
+ or h
+ ret z
+ jp hl
+
+DebugRoom_PageString:
+ db " P @"
+
+DebugRoom_IncrementPagedValue:
+ call DebugRoom_GetCurPagedValuePtr
+ ld e, [hl] ; de = value address
+ inc hl
+ ld d, [hl]
+ inc hl
+ inc hl
+ ld a, [de] ; a = max value
+ cp [hl]
+ ret z
+ inc a
+ ld [de], a
+ call DebugRoom_PrintPageBValueC
+ ret
+
+DebugRoom_DecrementPagedValue:
+ call DebugRoom_GetCurPagedValuePtr
+ ld e, [hl] ; de = value address
+ inc hl
+ ld d, [hl]
+ inc hl
+ ld a, [de] ; a = min value
+ cp [hl]
+ ret z
+ dec a
+ ld [de], a
+ call DebugRoom_PrintPageBValueC
+ ret
+
+DebugRoom_NextPage:
+ ld a, [wDebugRoomPageCount]
+ ld c, a
+ ld a, [wDebugRoomCurPage]
+ inc a
+ cp c
+ jr c, .ok
+ xor a
+.ok
+ ld [wDebugRoomCurPage], a
+ call DebugRoom_PrintPage
+ ld a, [wDebugRoomCurPage]
+ call DebugRoom_GetNthPagePtr
+ ld a, [wDebugRoomCurValue]
+ cp [hl]
+ jr c, .skip
+ ld a, [hl]
+ dec a
+ ld [wDebugRoomCurValue], a
+.skip
+ ld a, "▶"
+ call DebugRoom_ShowHideCursor
+ ret
+
+DebugRoom_PrevPage:
+ ld a, [wDebugRoomCurPage]
+ or a
+ jr nz, .ok
+ ld a, [wDebugRoomPageCount]
+.ok
+ dec a
+ ld [wDebugRoomCurPage], a
+ call DebugRoom_PrintPage
+ ld a, [wDebugRoomCurPage]
+ call DebugRoom_GetNthPagePtr
+ ld a, [wDebugRoomCurValue]
+ cp [hl]
+ jr c, .skip
+ ld a, [hl]
+ dec a
+ ld [wDebugRoomCurValue], a
+.skip
+ ld a, "▶"
+ call DebugRoom_ShowHideCursor
+ ret
+
+DebugRoom_NextPagedValue:
+ ld a, " "
+ call DebugRoom_ShowHideCursor
+ ld a, [wDebugRoomCurPage]
+ call DebugRoom_GetNthPagePtr
+ ld a, [wDebugRoomCurValue]
+ inc a
+ cp [hl] ; incremented value < paged_value count?
+ jr c, DebugRoom_UpdateValueCursor
+ xor a
+ ld [wDebugRoomCurValue], a
+ jr DebugRoom_NextPage
+
+DebugRoom_UpdateValueCursor:
+ ld [wDebugRoomCurValue], a
+ ld a, "▶"
+ call DebugRoom_ShowHideCursor
+ ret
+
+DebugRoom_PrevPagedValue:
+ ld a, " "
+ call DebugRoom_ShowHideCursor
+ ld a, [wDebugRoomCurValue]
+ or a ; pre-decremented value > 0?
+ jr nz, .decrement
+ ld a, -1
+ ld [wDebugRoomCurValue], a
+ jr DebugRoom_PrevPage
+
+.decrement:
+ dec a
+ jr DebugRoom_UpdateValueCursor
+
+DebugRoom_GetNthPagePtr:
+; Input: a = page index
+; Output: hl = pointer to paged_data list
+ ld h, 0
+ ld l, a
+ add hl, hl
+ ld a, [wDebugRoomPagedValuesPtr]
+ ld e, a
+ ld a, [wDebugRoomPagedValuesPtr+1]
+ ld d, a
+ add hl, de
+ ld a, [hli]
+ ld h, [hl]
+ ld l, a
+ ret
+
+_DebugRoom_GetPageBValueCPtr:
+ push bc
+ ld a, b
+ call DebugRoom_GetNthPagePtr
+ pop bc
+ inc hl
+ ld a, c
+ ld bc, PAGED_VALUE_SIZE
+ call AddNTimes
+ ret
+
+DebugRoom_GetCurPagedValuePtr:
+ ld a, [wDebugRoomCurPage]
+ ld b, a
+ ld a, [wDebugRoomCurValue]
+ ld c, a
+ jr _DebugRoom_GetPageBValueCPtr
+
+DebugRoom_ShowHideCursor:
+ push af
+ hlcoord 1, 1
+ ld bc, SCREEN_WIDTH * 2
+ ld a, [wDebugRoomCurValue]
+ call AddNTimes
+ pop af
+ ld [hl], a
+ ret
+
+DebugRoom_InitializePagedValues:
+; Load the initial values for all pages of the current paged value header
+ ld a, [wDebugRoomPageCount]
+.page_loop
+ dec a
+ push af
+ call .InitializePage
+ pop af
+ jr nz, .page_loop
+ ret
+
+.InitializePage:
+; Load the initial values for page a
+ ld b, a
+ ld h, 0
+ ld l, a
+ add hl, hl
+ ld a, [wDebugRoomPagedValuesPtr]
+ ld e, a
+ ld a, [wDebugRoomPagedValuesPtr+1]
+ ld d, a
+ add hl, de
+ ld a, [hli]
+ ld h, [hl]
+ ld l, a
+ ld c, [hl] ; c = paged_value count
+.value_loop
+ push bc
+ dec c
+ call .InitializeValue
+ pop bc
+ dec c
+ jr nz, .value_loop
+ ret
+
+.InitializeValue:
+; Load the initial value for page b, value c
+ ld h, 0
+ ld l, b
+ add hl, hl
+ ld a, [wDebugRoomPagedValuesPtr]
+ ld e, a
+ ld a, [wDebugRoomPagedValuesPtr+1]
+ ld d, a
+ add hl, de
+ ld a, [hli]
+ ld h, [hl]
+ ld l, a
+ inc hl ; skip the paged_value count
+ ld a, c
+ push bc
+ ld bc, PAGED_VALUE_SIZE
+ call AddNTimes
+ pop bc
+ ld e, [hl] ; de = value address
+ inc hl
+ ld d, [hl]
+ inc hl
+ inc hl
+ inc hl
+ ld a, [hl] ; a = initial value
+ ld [de], a
+ ret
+
+DebugRoom_PrintPage:
+ push af
+ hlcoord 10, 17
+ add "1"
+ ld [hl], a
+ hlcoord 1, 1
+ lb bc, SCREEN_HEIGHT - 2, SCREEN_WIDTH - 2
+ call ClearBox
+ pop af
+ ld b, a
+ ld h, 0
+ ld l, a
+ add hl, hl
+ ld a, [wDebugRoomPagedValuesPtr]
+ ld e, a
+ ld a, [wDebugRoomPagedValuesPtr+1]
+ ld d, a
+ add hl, de
+ ld a, [hli]
+ ld h, [hl]
+ ld l, a
+ ld c, [hl] ; c = paged_value count
+.loop
+ push bc
+ dec c
+ call DebugRoom_PrintPagedValue
+ pop bc
+ dec c
+ jr nz, .loop
+ ret
+
+DebugRoom_PrintPageBValueC:
+ ld a, [wDebugRoomCurPage]
+ ld b, a
+ ld a, [wDebugRoomCurValue]
+ ld c, a
+ jr DebugRoom_PrintPagedValue
+
+DebugRoom_PrintPagedValue:
+; Print the value for page b, value c
+ ld h, 0
+ ld l, b
+ add hl, hl
+ ld a, [wDebugRoomPagedValuesPtr]
+ ld e, a
+ ld a, [wDebugRoomPagedValuesPtr+1]
+ ld d, a
+ add hl, de
+ ld a, [hli]
+ ld h, [hl]
+ ld l, a
+ inc hl ; skip the paged_value count
+ ld a, c
+ push bc
+ ld bc, PAGED_VALUE_SIZE
+ call AddNTimes
+ pop bc
+ ld e, [hl] ; de = value address
+ inc hl
+ ld d, [hl]
+ inc hl
+ push de
+ inc hl
+ inc hl
+ inc hl
+ ld e, [hl] ; de = label string
+ inc hl
+ ld d, [hl]
+ inc hl
+ push hl
+ hlcoord 2, 1
+ ld a, c
+ ld bc, SCREEN_WIDTH * 2
+ call AddNTimes
+ push hl
+ call PlaceString
+ pop hl
+ ld bc, SCREEN_WIDTH - 7
+ add hl, bc
+ pop bc ; pushed hl
+ pop de
+ push de
+ push bc
+ inc bc
+ inc bc
+ ld a, [bc] ; a = is hex value?
+ or a
+ jr nz, .hex
+ lb bc, PRINTNUM_LEADINGZEROS | 1, 3
+ call PrintNum
+ jr .printed
+.hex
+ ld c, 1
+ call PrintHexNumber
+ ld [hl], "H"
+ inc hl
+.printed
+ ld bc, 6
+ add hl, bc
+ ld b, h
+ ld c, l
+ pop hl
+ pop de
+ ld a, [hli] ; hl = value name function
+ ld h, [hl]
+ ld l, a
+ or h
+ ret z
+ ld a, [de]
+ jp hl
+
+DebugRoom_JoyWaitABSelect:
+.loop
+ call GetJoypad
+ ldh a, [hJoyPressed]
+ and A_BUTTON | B_BUTTON | SELECT
+ jr z, .loop
+ ret
+
+DebugRoomMenu_ItemGet:
+ ld hl, .PagedValuesHeader
+ call DebugRoom_EditPagedValues
+ ret
+
+.PagedValuesHeader:
+ dw NULL ; A function
+ dw NULL ; Select function
+ dw DebugRoom_SaveItem ; Start function
+ dw NULL ; Auto function
+ db 1 ; # pages
+ dw DebugRoomMenu_ItemGet_Page1Values
+
+DebugRoom_SaveItem:
+ call YesNoBox
+ ret c
+ ld a, BANK(sPlayerData3)
+ call OpenSRAM
+ ld hl, sPlayerData3 + (wPCItems - wPlayerData3)
+ ld a, [wDebugRoomItemID]
+ ld c, a
+.loop1
+ ld a, [hl]
+ cp c
+ jr z, .found
+ cp -1
+ jr z, .not_found
+ inc hl
+ inc hl
+ jr .loop1
+
+.found
+ inc hl
+ ld a, [wDebugRoomItemQuantity]
+ add [hl]
+ cp MAX_ITEM_STACK + 1
+ jr c, .max
+ ld a, MAX_ITEM_STACK
+.max
+ ld [hl], a
+ ld hl, .ItemNumberAddedText
+ jr .done
+
+.not_found
+ ld a, [sPlayerData3 + (wNumPCItems - wPlayerData3)]
+ cp MAX_PC_ITEMS
+ jr nc, .full
+ inc a
+ ld [sPlayerData3 + (wNumPCItems - wPlayerData3)], a
+ ld a, [wDebugRoomItemID]
+ ld [hli], a
+ ld a, [wDebugRoomItemQuantity]
+ ld [hli], a
+ ld [hl], -1 ; terminator
+ ld hl, .CreatedNewItemText
+ jr .done
+
+.full
+ ld hl, .StockFullText
+.done
+ call CloseSRAM
+ call MenuTextbox
+ call DebugRoom_JoyWaitABSelect
+ call CloseWindow
+ call DebugRoom_SaveChecksum
+ ret
+
+.ItemNumberAddedText:
+ text "Item number added!"
+ done
+
+.CreatedNewItemText:
+ text "Created new item!"
+ done
+
+.StockFullText:
+ text "Stock full!!"
+ done
+
+DebugRoom_PrintItemName:
+ ld [wNamedObjectIndexBuffer], a
+ push bc
+ call GetItemName
+ pop hl
+ push hl
+ lb bc, 1, 12
+ call ClearBox
+ pop hl
+ ld de, wStringBuffer1
+ call PlaceString
+ ret
+
+DebugRoomMenu_ItemGet_Page1Values:
+ db 2
+ paged_value wDebugRoomItemID, 1, NUM_POKEMON, MASTER_BALL, .ItemNameString, DebugRoom_PrintItemName, FALSE
+ paged_value wDebugRoomItemQuantity, 1, 99, 1, .NumberString, NULL, FALSE
+
+.ItemNameString: db "ITEM NAME@"
+.NumberString: db "NUMBER@"
+
+DebugRoomMenu_PokemonGet:
+ ld hl, .PagedValuesHeader
+ call DebugRoom_EditPagedValues
+ ret
+
+.PagedValuesHeader:
+ dw NULL ; A function
+ dw NULL ; Select function
+ dw DebugRoom_SavePokemon ; Start function
+ dw NULL ; Auto function
+ db 4 ; # pages
+ dw DebugRoomMenu_PokemonGet_Page1Values
+ dw DebugRoomMenu_PokemonGet_Page2Values
+ dw DebugRoomMenu_PokemonGet_Page3Values
+ dw DebugRoomMenu_PokemonGet_Page4Values
+
+DebugRoom_SavePokemon:
+ call YesNoBox
+ ret c
+ call DebugRoom_UpdateExpForLevel
+ ld a, [wDebugRoomMonBox]
+ dec a
+ ld b, a
+ add a
+ add b
+ ld h, 0
+ ld l, a
+ ld de, DebugRoom_BoxAddresses
+ add hl, de
+ ld a, [hli]
+ call OpenSRAM
+ ld a, [hli]
+ ld h, [hl]
+ ld l, a
+ ld a, [hl]
+ cp MONS_PER_BOX
+ jr nc, .full
+ ; update count and species list
+ push hl
+ inc [hl]
+ inc hl
+ ld d, 0
+ ld e, a
+ add hl, de
+ ld a, [wDebugRoomMonSpecies]
+ ld [hli], a
+ ld [hl], -1
+ pop hl
+ ; skip count and species list
+ ld bc, 2 + MONS_PER_BOX
+ add hl, bc
+ ; update Nth box mon
+ push de
+ push hl
+ ld a, e
+ ld bc, BOXMON_STRUCT_LENGTH
+ call AddNTimes
+ ld d, h
+ ld e, l
+ ld hl, wDebugRoomMon
+ ld bc, BOXMON_STRUCT_LENGTH
+ call CopyBytes
+ pop hl
+ pop de
+ ; skip box mons
+ ld bc, BOXMON_STRUCT_LENGTH * MONS_PER_BOX
+ add hl, bc
+ ; update Nth OT name
+ push de
+ push hl
+ ld a, e
+ ld bc, NAME_LENGTH
+ call AddNTimes
+ ld d, h
+ ld e, l
+ ld hl, .OTString
+ ld bc, NAME_LENGTH
+ call CopyBytes
+ pop hl
+ pop de
+ ; skip OT names
+ ld bc, NAME_LENGTH * MONS_PER_BOX
+ add hl, bc
+ ; update Nth nickname
+ push de
+ push hl
+ ld a, e
+ ld bc, MON_NAME_LENGTH
+ call AddNTimes
+ ld d, h
+ ld e, l
+ ld hl, .NicknameString
+ ld bc, MON_NAME_LENGTH
+ call CopyBytes
+ pop hl
+ pop de
+ call CloseSRAM
+ ld hl, .CompletedText
+ call MenuTextbox
+ call DebugRoom_JoyWaitABSelect
+ call CloseWindow
+ ret
+
+.full
+ call CloseSRAM
+ ld hl, .BoxIsFullText
+ call MenuTextbox
+ call DebugRoom_JoyWaitABSelect
+ call CloseWindow
+ ret
+
+.OTString:
+ db "DEBUG▶OT@"
+
+.NicknameString:
+ db "DEBUG▶<PK><MN>@"
+
+.CompletedText:
+ text "COMPLETED!"
+ done
+
+.BoxIsFullText:
+ text "BOX IS FULL!"
+ done
+
+DebugRoom_PrintPokemonName:
+ ld [wNamedObjectIndexBuffer], a
+ push bc
+ call GetPokemonName
+ jr _DebugRoom_FinishGetName
+
+DebugRoom_PrintItemName2:
+ ld [wNamedObjectIndexBuffer], a
+ push bc
+ call GetItemName
+ jr _DebugRoom_FinishGetName
+
+DebugRoom_PrintMoveName:
+ ld [wNamedObjectIndexBuffer], a
+ push bc
+ call GetMoveName
+ jr _DebugRoom_FinishGetName
+
+_DebugRoom_FinishGetName:
+ pop hl
+ push hl
+ lb bc, 1, 12
+ call ClearBox
+ pop hl
+ ld de, wStringBuffer1
+ call PlaceString
+ ret
+
+DebugRoom_UpdateExpForLevel:
+ ld hl, BaseData + BASE_GROWTH_RATE
+ ld bc, BASE_DATA_SIZE
+ ld a, [wDebugRoomMonSpecies]
+ dec a
+ call AddNTimes
+ ld a, BANK(BaseData)
+ call GetFarByte
+ ld [wBaseGrowthRate], a
+ ld a, [wDebugRoomMonLevel]
+ ld d, a
+ farcall CalcExpAtLevel
+ ld hl, wDebugRoomMonExp
+ ldh a, [hProduct + 1]
+ ld [hli], a
+ ldh a, [hProduct + 2]
+ ld [hli], a
+ ldh a, [hProduct + 3]
+ ld [hl], a
+ ret
+
+DebugRoomMenu_PokemonGet_Page1Values:
+ db 8
+ paged_value wDebugRoomMonSpecies, 1, NUM_POKEMON, BULBASAUR, DebugRoom_BoxStructStrings.Pokemon, DebugRoom_PrintPokemonName, FALSE
+ paged_value wDebugRoomMonItem, 1, $ff, MASTER_BALL, DebugRoom_BoxStructStrings.Item, DebugRoom_PrintItemName2, FALSE
+ paged_value wDebugRoomMonMoves+0, 1, NUM_ATTACKS, POUND, DebugRoom_BoxStructStrings.Move1, DebugRoom_PrintMoveName, FALSE
+ paged_value wDebugRoomMonMoves+1, 1, NUM_ATTACKS, POUND, DebugRoom_BoxStructStrings.Move2, DebugRoom_PrintMoveName, FALSE
+ paged_value wDebugRoomMonMoves+2, 1, NUM_ATTACKS, POUND, DebugRoom_BoxStructStrings.Move3, DebugRoom_PrintMoveName, FALSE
+ paged_value wDebugRoomMonMoves+3, 1, NUM_ATTACKS, POUND, DebugRoom_BoxStructStrings.Move4, DebugRoom_PrintMoveName, FALSE
+ paged_value wDebugRoomMonID+0, $00, $ff, HIGH(1234), DebugRoom_BoxStructStrings.ID0, NULL, FALSE
+ paged_value wDebugRoomMonID+1, $00, $ff, LOW(1234), DebugRoom_BoxStructStrings.ID1, NULL, FALSE
+
+DebugRoomMenu_PokemonGet_Page2Values:
+ db 8
+ paged_value wDebugRoomMonHPExp+0, $00, $ff, $00, DebugRoom_BoxStructStrings.HPExp0, NULL, FALSE
+ paged_value wDebugRoomMonHPExp+1, $00, $ff, $00, DebugRoom_BoxStructStrings.HPExp1, NULL, FALSE
+ paged_value wDebugRoomMonAtkExp+0, $00, $ff, $00, DebugRoom_BoxStructStrings.AttkExp0, NULL, FALSE
+ paged_value wDebugRoomMonAtkExp+1, $00, $ff, $00, DebugRoom_BoxStructStrings.AttkExp1, NULL, FALSE
+ paged_value wDebugRoomMonDefExp+0, $00, $ff, $00, DebugRoom_BoxStructStrings.DfnsExp0, NULL, FALSE
+ paged_value wDebugRoomMonDefExp+1, $00, $ff, $00, DebugRoom_BoxStructStrings.DfnsExp1, NULL, FALSE
+ paged_value wDebugRoomMonSpdExp+0, $00, $ff, $00, DebugRoom_BoxStructStrings.SpeedExp0, NULL, FALSE
+ paged_value wDebugRoomMonSpdExp+1, $00, $ff, $00, DebugRoom_BoxStructStrings.SpeedExp1, NULL, FALSE
+
+DebugRoomMenu_PokemonGet_Page3Values:
+ db 8
+ paged_value wDebugRoomMonSpcExp+0, $00, $ff, $00, DebugRoom_BoxStructStrings.SpclExp0, NULL, FALSE
+ paged_value wDebugRoomMonSpcExp+1, $00, $ff, $00, DebugRoom_BoxStructStrings.SpclExp1, NULL, FALSE
+ paged_value wDebugRoomMonDVs+0, $00, $ff, $00, DebugRoom_BoxStructStrings.PowerRnd0, NULL, TRUE
+ paged_value wDebugRoomMonDVs+1, $00, $ff, $00, DebugRoom_BoxStructStrings.PowerRnd1, NULL, TRUE
+ paged_value wDebugRoomMonPP+0, $00, $ff, $00, DebugRoom_BoxStructStrings.PP1, NULL, FALSE
+ paged_value wDebugRoomMonPP+1, $00, $ff, $00, DebugRoom_BoxStructStrings.PP2, NULL, FALSE
+ paged_value wDebugRoomMonPP+2, $00, $ff, $00, DebugRoom_BoxStructStrings.PP3, NULL, FALSE
+ paged_value wDebugRoomMonPP+3, $00, $ff, $00, DebugRoom_BoxStructStrings.PP4, NULL, FALSE
+
+DebugRoomMenu_PokemonGet_Page4Values:
+ db 6
+ paged_value wDebugRoomMonHappiness, $00, $ff, BASE_HAPPINESS, DebugRoom_BoxStructStrings.Friend, NULL, FALSE
+ paged_value wDebugRoomMonPokerusStatus, $00, $ff, $00, DebugRoom_BoxStructStrings.Pokerus, NULL, TRUE
+ paged_value wDebugRoomMonUnused1, $00, $ff, $00, DebugRoom_BoxStructStrings.NoUse0, NULL, FALSE
+ paged_value wDebugRoomMonUnused2, $00, $ff, $00, DebugRoom_BoxStructStrings.NoUse1, NULL, FALSE
+ paged_value wDebugRoomMonLevel, 1, MAX_LEVEL, $05, DebugRoom_BoxStructStrings.Level, NULL, FALSE
+ paged_value wDebugRoomMonBox, 1, NUM_BOXES, $0e, DebugRoom_BoxStructStrings.SendBox, NULL, FALSE
+
+DebugRoom_BoxStructStrings:
+.Pokemon: db "#MON@"
+.Item: db "ITEM@"
+.Move1: db "MOVE 1@"
+.Move2: db "MOVE 2@"
+.Move3: db "MOVE 3@"
+.Move4: db "MOVE 4@"
+.ID0: db "ID[0]@"
+.ID1: db "ID[1]@"
+.BaseExp0: db "BASE EXP[0]@"
+.BaseExp1: db "BASE EXP[1]@"
+.BaseExp2: db "BASE EXP[2]@"
+.HPExp0: db "HP EXP[0]@"
+.HPExp1: db "HP EXP[1]@"
+.AttkExp0: db "ATTK EXP[0]@"
+.AttkExp1: db "ATTK EXP[1]@"
+.DfnsExp0: db "DFNS EXP[0]@"
+.DfnsExp1: db "DFNS EXP[1]@"
+.SpeedExp0: db "SPEED EXP[0]@"
+.SpeedExp1: db "SPEED EXP[1]@"
+.SpclExp0: db "SPCL EXP[0]@"
+.SpclExp1: db "SPCL EXP[1]@"
+.PowerRnd0: db "POWER RND[0]<LF> RARE:--1-1010@"
+.PowerRnd1: db "POWER RND[1]<LF> RARE:10101010@"
+.PP1: db "PP 1@"
+.PP2: db "PP 2@"
+.PP3: db "PP 3@"
+.PP4: db "PP 4@"
+.Friend: db "FRIEND@"
+.Pokerus: db "#RUS@"
+.NoUse0: db "NO USE[0]@"
+.NoUse1: db "NO USE[1]@"
+.Level: db "LEVEL@"
+.SendBox: db "SEND BOX@"
+
+DebugRoom_BoxAddresses:
+ dba sBox1
+ dba sBox2
+ dba sBox3
+ dba sBox4
+ dba sBox5
+ dba sBox6
+ dba sBox7
+ dba sBox8
+ dba sBox9
+ dba sBox10
+ dba sBox11
+ dba sBox12
+ dba sBox13
+ dba sBox14
+
+DebugRoomMenu_RTCEdit:
+ ld hl, .PagedValuesHeader
+ call DebugRoom_EditPagedValues
+ ret
+
+.PagedValuesHeader:
+ dw NULL ; A function
+ dw NULL ; Select function
+ dw DebugRoom_SaveRTC ; Start function
+ dw DebugRoomMenu_RTCEdit_UpdateClock ; Auto function
+ db 1 ; # pages
+ dw DebugRoomMenu_RTCEdit_Page1Values
+
+DebugRoom_SaveRTC:
+ call YesNoBox
+ ret c
+ ld hl, wDebugRoomRTCSec
+ call DebugRoom_SetClock
+ ret
+
+DebugRoomMenu_RTCEdit_UpdateClock:
+ ld hl, wDebugRoomRTCCurSec
+ call DebugRoom_GetClock
+ ld de, DebugRoom_DayHTimeString
+ hlcoord 3, 14
+ call PlaceString
+ ld a, [wDebugRoomRTCCurDay + 0]
+ ld h, a
+ ld a, [wDebugRoomRTCCurDay + 1]
+ ld l, a
+ push hl
+ ld hl, sp+0
+ ld d, h
+ ld e, l
+ hlcoord 7, 14
+ ld c, 2
+ call PrintHexNumber
+ pop hl
+ hlcoord 8, 15
+ ld de, wDebugRoomRTCCurHour
+ lb bc, PRINTNUM_LEADINGZEROS | 1, 2
+ call PrintNum
+ ld [hl], ":"
+ inc hl
+ ld de, wDebugRoomRTCCurMin
+ lb bc, PRINTNUM_LEADINGZEROS | 1, 2
+ call PrintNum
+ ld [hl], ":"
+ inc hl
+ ld de, wDebugRoomRTCCurSec
+ lb bc, PRINTNUM_LEADINGZEROS | 1, 2
+ call PrintNum
+ ret
+
+DebugRoom_DayHTimeString:
+ db "DAY H<LF>TIME@"
+
+DebugRoom_GetClock:
+ ld a, SRAM_ENABLE
+ ld [MBC3SRamEnable], a
+ xor a
+ ld [MBC3LatchClock], a
+ inc a
+ ld [MBC3LatchClock], a
+ ld b, RTC_DH - RTC_S + 1
+ ld c, RTC_S
+.loop
+ ld a, c
+ ld [MBC3SRamBank], a
+ ld a, [MBC3RTC]
+ ld [hli], a
+ inc c
+ dec b
+ jr nz, .loop
+ call CloseSRAM
+ ret
+
+DebugRoom_SetClock:
+ ld a, SRAM_ENABLE
+ ld [MBC3SRamEnable], a
+ ld b, RTC_DH - RTC_S + 1
+ ld c, RTC_S
+.loop
+ ld a, c
+ ld [MBC3SRamBank], a
+ ld a, [hli]
+ ld [MBC3RTC], a
+ inc c
+ dec b
+ jr nz, .loop
+ call CloseSRAM
+ ret
+
+DebugRoomMenu_RTCEdit_Page1Values:
+ db 5
+ paged_value wDebugRoomRTCSec, 0, 60 - 1, 0, .SecondString, NULL, FALSE
+ paged_value wDebugRoomRTCMin, 0, 60 - 1, 0, .MinuteString, NULL, FALSE
+ paged_value wDebugRoomRTCHour, 0, 24 - 1, 0, .HourString, NULL, FALSE
+ paged_value wDebugRoomRTCDay+0, $00, $ff, 0, .DayLString, NULL, TRUE
+ paged_value wDebugRoomRTCDay+1, $00, $ff, 0, .DayHString, NULL, TRUE
+
+.SecondString: db "SECOND@"
+.MinuteString: db "MINUTE@"
+.HourString: db "HOUR@"
+.DayLString: db "DAY L@"
+.DayHString: db "DAY H<LF> BIT0:DAY MSB<LF> BIT6:HALT<LF> BIT7:DAY CARRY@"
+
+DebugRoomMenu_HaltChkClr:
+ call YesNoBox
+ ret c
+ ld a, BANK(sRTCHaltCheckValue)
+ call OpenSRAM
+ xor a
+ ld hl, sRTCHaltCheckValue
+ ld [hli], a
+ ld [hl], a
+ call CloseSRAM
+ call DebugRoom_PrintRTCHaltChk
+ ret
+
+DebugRoom_PrintRTCHaltChk:
+ hlcoord 16, 8
+ ld de, .RTCString
+ call PlaceString
+ ld a, BANK(sRTCHaltCheckValue)
+ ld hl, sRTCHaltCheckValue
+ call OpenSRAM
+ ld a, [hli]
+ ld h, [hl]
+ ld l, a
+ call CloseSRAM
+ ld de, .HaltString
+ ld a, h
+ cp HIGH(RTC_HALT_VALUE)
+ jr nz, .ok
+ ld a, l
+ cp LOW(RTC_HALT_VALUE)
+ jr z, .done
+.ok
+ ld de, .OKString
+.done
+ hlcoord 16, 9
+ call PlaceString
+ ret
+
+.RTCString:
+ db "RTC:@"
+
+.OKString:
+ db " OK@"
+
+.HaltString:
+ db "HALT@"
+
+DebugRoomMenu_GBIDSet:
+ ld hl, .PagedValuesHeader
+ call DebugRoom_EditPagedValues
+ ret
+
+.PagedValuesHeader:
+ dw NULL ; A function
+ dw NULL ; Select function
+ dw DebugRoom_SaveGBID ; Start function
+ dw NULL ; Auto function
+ db 1 ; # pages
+ dw DebugRoomMenu_GBIDSet_Page1Values
+
+DebugRoom_SaveGBID:
+ call YesNoBox
+ ret c
+ ld a, BANK(sPlayerData)
+ call OpenSRAM
+ ld hl, sPlayerData + (wPlayerID - wPlayerData)
+ ld a, [wDebugRoomGBID + 0]
+ ld [hli], a
+ ld a, [wDebugRoomGBID + 1]
+ ld [hli], a
+ call CloseSRAM
+ call DebugRoom_SaveChecksum
+ ret
+
+DebugRoomMenu_GBIDSet_Page1Values:
+ db 2
+ paged_value wDebugRoomGBID+0, $00, $ff, $00, .GBID0String, NULL, TRUE
+ paged_value wDebugRoomGBID+1, $00, $ff, $00, .GBID1String, NULL, TRUE
+
+.GBID0String: db "GB ID [0]@"
+.GBID1String: db "GB ID [1]@"
+
+DebugRoomMenu_BtlRecClr:
+ call YesNoBox
+ ret c
+ ld a, BANK(sLinkBattleStats)
+ call OpenSRAM
+ xor a
+ ld hl, sLinkBattleStats
+ ld bc, sLinkBattleStatsEnd - sLinkBattleStats
+ call ByteFill
+ call CloseSRAM
+ ret
diff --git a/engine/items/items.asm b/engine/items/items.asm
index a08f76d3..78b0e2cd 100644
--- a/engine/items/items.asm
+++ b/engine/items/items.asm
@@ -168,7 +168,7 @@ PutItemInPocket:
jr z, .terminator
cp c
jr nz, .next
- ld a, 99
+ ld a, MAX_ITEM_STACK
sub [hl]
add b
ld b, a
@@ -205,14 +205,14 @@ PutItemInPocket:
jr nz, .loop2
ld a, [wItemQuantityBuffer]
add [hl]
- cp 100
+ cp MAX_ITEM_STACK + 1
jr nc, .newstack
ld [hl], a
jr .done
.newstack
- ld [hl], 99
- sub 99
+ ld [hl], MAX_ITEM_STACK
+ sub MAX_ITEM_STACK
ld [wItemQuantityBuffer], a
jr .loop2
@@ -408,7 +408,7 @@ ReceiveTMHM:
add hl, bc
ld a, [wItemQuantityChangeBuffer]
add [hl]
- cp 100
+ cp MAX_ITEM_STACK + 1
jr nc, .toomany
ld [hl], a
scf
diff --git a/engine/items/mart.asm b/engine/items/mart.asm
index edf8f5b5..3e7ffc0e 100644
--- a/engine/items/mart.asm
+++ b/engine/items/mart.asm
@@ -472,7 +472,7 @@ BuyMenuLoop:
ret
StandardMartAskPurchaseQuantity:
- ld a, 99
+ ld a, MAX_ITEM_STACK
ld [wItemQuantityBuffer], a
ld a, MARTTEXT_HOW_MANY
call LoadBuyMenuText
diff --git a/engine/items/switch_items.asm b/engine/items/switch_items.asm
index cb1554d7..794362ba 100644
--- a/engine/items/switch_items.asm
+++ b/engine/items/switch_items.asm
@@ -96,11 +96,11 @@ Function248cf:
jr nz, .asm_248f5
ld a, [wScrollingMenuCursorPosition]
call Function249bf
- cp 99
+ cp MAX_ITEM_STACK
jr z, .asm_248f5
ld a, [wSwitchItem]
call Function249bf
- cp 99
+ cp MAX_ITEM_STACK
jr nz, .asm_248f7
.asm_248f5
and a
@@ -121,14 +121,14 @@ Function248f9:
ld a, [hl]
pop hl
add [hl]
- cp 100
+ cp MAX_ITEM_STACK + 1
jr c, .asm_24929
- sub 99
+ sub MAX_ITEM_STACK
push af
ld a, [wScrollingMenuCursorPosition]
call ItemSwitch_GetNthItem
inc hl
- ld [hl], 99
+ ld [hl], MAX_ITEM_STACK
ld a, [wSwitchItem]
call ItemSwitch_GetNthItem
inc hl
diff --git a/engine/menus/intro_menu.asm b/engine/menus/intro_menu.asm
index 8b12b991..3fdc42cd 100644
--- a/engine/menus/intro_menu.asm
+++ b/engine/menus/intro_menu.asm
@@ -13,6 +13,12 @@ NewGame:
ldh [hMapEntryMethod], a
jp FinishContinueFunction
+IF DEF(_DEBUG)
+DebugRoom:
+ farcall _DebugRoom
+ ret
+ENDC
+
ResetWRAM:
xor a
ldh [hBGMapMode], a
diff --git a/engine/menus/main_menu.asm b/engine/menus/main_menu.asm
index 141f6987..6f8727a7 100644
--- a/engine/menus/main_menu.asm
+++ b/engine/menus/main_menu.asm
@@ -10,6 +10,9 @@
const MAINMENUITEM_NEW_GAME ; 1
const MAINMENUITEM_OPTION ; 2
const MAINMENUITEM_MYSTERY_GIFT ; 3
+IF DEF(_DEBUG)
+ const MAINMENUITEM_DEBUG_ROOM ; 4
+ENDC
MainMenu:
ld de, MUSIC_NONE
@@ -46,7 +49,11 @@ MainMenu:
.MenuHeader:
db MENU_BACKUP_TILES ; flags
+IF DEF(_DEBUG)
+ menu_coords 0, 0, 14, 9
+ELSE
menu_coords 0, 0, 14, 7
+ENDC
dw .MenuData
db 1 ; default option
@@ -63,6 +70,9 @@ MainMenu:
db "NEW GAME@"
db "OPTION@"
db "MYSTERY GIFT@"
+IF DEF(_DEBUG)
+ db "DEBUG ROOM@"
+ENDC
.Jumptable:
; entries correspond to MAINMENUITEM_* constants
@@ -70,6 +80,9 @@ MainMenu:
dw NewGame
dw Option
dw MysteryGift
+IF DEF(_DEBUG)
+ dw DebugRoom
+ENDC
MainMenuItems:
; entries correspond to MAINMENU_* constants
@@ -81,18 +94,24 @@ MainMenuItems:
db -1
; MAINMENU_CONTINUE
- db 3
+ db 3 + DEF(_DEBUG)
db MAINMENUITEM_CONTINUE
db MAINMENUITEM_NEW_GAME
db MAINMENUITEM_OPTION
+IF DEF(_DEBUG)
+ db MAINMENUITEM_DEBUG_ROOM
+ENDC
db -1
; MAINMENU_MYSTERY
- db 4
+ db 4 + DEF(_DEBUG)
db MAINMENUITEM_CONTINUE
db MAINMENUITEM_NEW_GAME
db MAINMENUITEM_OPTION
db MAINMENUITEM_MYSTERY_GIFT
+IF DEF(_DEBUG)
+ db MAINMENUITEM_DEBUG_ROOM
+ENDC
db -1
MainMenu_GetWhichMenu:
diff --git a/engine/rtc/rtc.asm b/engine/rtc/rtc.asm
index dcd8494d..3e765b87 100644
--- a/engine/rtc/rtc.asm
+++ b/engine/rtc/rtc.asm
@@ -130,12 +130,12 @@ _GetClock:
bit 6, a ; halt
ret z
- ld a, BANK(sRTCStatusFlags)
+ ld a, BANK(sRTCHaltCheckValue)
call OpenSRAM
- ld a, $34
- ld [sUnusedRTCMinutes], a
- ld a, $12
- ld [sUnusedRTCHours], a
+ ld a, LOW(RTC_HALT_VALUE)
+ ld [sRTCHaltCheckValue + 0], a
+ ld a, HIGH(RTC_HALT_VALUE)
+ ld [sRTCHaltCheckValue + 1], a
call CloseSRAM
ret
diff --git a/home/map.asm b/home/map.asm
index 8a138be8..2701f477 100644
--- a/home/map.asm
+++ b/home/map.asm
@@ -1043,7 +1043,7 @@ MaskObject::
ld d, $0
ld hl, wObjectMasks
add hl, de
- ld [hl], -1 ; , masked
+ ld [hl], -1 ; masked
ret
UnmaskObject::
diff --git a/hram.asm b/hram.asm
index 44b7b4a3..3b3b3df6 100644
--- a/hram.asm
+++ b/hram.asm
@@ -160,4 +160,10 @@ hCGBPalUpdate:: db
hCGB:: db
hSGB:: db
- ds 21
+IF DEF(_DEBUG)
+hDebugRoomMenuPage:: db
+ELSE
+ ds 1
+ENDC
+
+ ds 20
diff --git a/layout.link b/layout.link
index 9a8133c1..866780e8 100644
--- a/layout.link
+++ b/layout.link
@@ -276,7 +276,7 @@ SRAM $00
"SRAM Bank 0"
"Backup Save 1"
"SRAM Stack"
- org $bfff
+ org $b800
"SRAM Window Stack"
SRAM $01
"Save"
diff --git a/main.asm b/main.asm
index 663d8206..c01fdf41 100644
--- a/main.asm
+++ b/main.asm
@@ -374,7 +374,7 @@ INCLUDE "engine/tilesets/tileset_anims.asm"
INCLUDE "engine/events/npc_trade.asm"
INCLUDE "engine/events/mom_phone.asm"
INCLUDE "engine/link/mystery_gift_3.asm"
-INCLUDE "engine/menus/debug.asm"
+INCLUDE "engine/debug/color_picker.asm"
SECTION "Standard Scripts", ROMX
@@ -421,6 +421,9 @@ INCLUDE "data/items/descriptions.asm"
SECTION "bank70", ROMX
INCLUDE "engine/printer/print_party.asm"
+IF DEF(_DEBUG)
+INCLUDE "engine/debug/debug_room.asm"
+ENDC
SECTION "bank70_2", ROMX
@@ -439,7 +442,15 @@ INCLUDE "data/credits_strings.asm"
SECTION "Stadium Data", ROMX
IF DEF(_GOLD)
+IF DEF(_DEBUG)
+INCBIN "data/stadium/stadium_gold_debug.bin"
+ELSE
INCBIN "data/stadium/stadium_gold.bin"
+ENDC
ELIF DEF(_SILVER)
+IF DEF(_DEBUG)
+INCBIN "data/stadium/stadium_silver_debug.bin"
+ELSE
INCBIN "data/stadium/stadium_silver.bin"
ENDC
+ENDC
diff --git a/roms.sha1 b/roms.sha1
index cc9ca7d1..e3e7c1df 100644
--- a/roms.sha1
+++ b/roms.sha1
@@ -1,2 +1,4 @@
d8b8a3600a465308c9953dfa04f0081c05bdcb94 *pokegold.gbc
49b163f7e57702bc939d642a18f591de55d92dae *pokesilver.gbc
+53783c57378122805c5b4859d19e1a224f02a1ed *pokegold_debug.gbc
+4c2fafebdbc7551f4cd3f348bdd17e420b93b6e7 *pokesilver_debug.gbc
diff --git a/sram.asm b/sram.asm
index 4fe687bb..b9354382 100644
--- a/sram.asm
+++ b/sram.asm
@@ -89,13 +89,16 @@ sBackupPlayerData1:: ds wPlayerData1End - wPlayerData
SECTION "SRAM Stack", SRAM
sStackTop:: dw
-sUnusedRTCMinutes:: db
-sUnusedRTCHours:: db
+sRTCHaltCheckValue:: dw
SECTION "SRAM Window Stack", SRAM
-sWindowStackTop:: ds 1
+sWindowStackBottom::
+ ds $800 - 1
+sWindowStack::
+sWindowStackTop::
+ ds 1
SECTION "Save", SRAM
diff --git a/wram.asm b/wram.asm
index dc122e96..3f490f0e 100644
--- a/wram.asm
+++ b/wram.asm
@@ -1060,6 +1060,33 @@ wBattleEnd::
ENDU
+IF DEF(_DEBUG)
+NEXTU
+; debug room paged values
+UNION
+; debug room new item values
+wDebugRoomItemID:: db
+wDebugRoomItemQuantity:: db
+NEXTU
+; debug room new pokemon values
+wDebugRoomMon:: box_struct wDebugRoomMon
+wDebugRoomMonBox:: db
+NEXTU
+; debug room RTC values
+wDebugRoomRTCSec:: db
+wDebugRoomRTCMin:: db
+wDebugRoomRTCHour:: db
+wDebugRoomRTCDay:: dw
+wDebugRoomRTCCurSec:: db
+wDebugRoomRTCCurMin:: db
+wDebugRoomRTCCurHour:: db
+wDebugRoomRTCCurDay:: dw
+NEXTU
+; debug room GB ID values
+wDebugRoomGBID:: dw
+ENDU
+ENDC
+
ENDU
@@ -1457,6 +1484,19 @@ wKeepSevenBiasChance:: ; used in the slots to handle the favoring of 7 symbol st
wStartFlypoint:: db
wEndFlypoint:: db
+IF DEF(_DEBUG)
+NEXTU
+; debug room paged values
+wDebugRoomCurPage:: db
+wDebugRoomCurValue:: db
+wDebugRoomAFunction:: dw
+wDebugRoomStartFunction:: dw
+wDebugRoomSelectFunction:: dw
+wDebugRoomAutoFunction:: dw
+wDebugRoomPageCount:: db
+wDebugRoomPagedValuesPtr:: dw
+ENDC
+
NEXTU
; unidentified
wceed:: db