ref: 71073a5f3bcbf4f2725e16bdce147c070c8b833e
parent: e791c5392b19f589c51afd98666d19e778278847
author: Rangi <remy.oukaour+rangi42@gmail.com>
date: Tue Mar 9 15:43:24 EST 2021
Verify RAM table lengths
--- a/constants/map_object_constants.asm
+++ b/constants/map_object_constants.asm
@@ -112,6 +112,8 @@
MAPOBJECT_EVENT_FLAG rw ; c
rb_skip 2
MAPOBJECT_LENGTH EQU _RS
+NUM_OBJECTS EQU 16
+PLAYER_OBJECT EQU 0
; SpriteMovementData struct members (see data/sprites/map_objects.asm)
rsreset
--- a/constants/wram_constants.asm
+++ b/constants/wram_constants.asm
@@ -184,10 +184,6 @@
const FRIDAY ; 5
const SATURDAY ; 6
-; wMapObjects::
-PLAYER_OBJECT EQU 0
-NUM_OBJECTS EQU 16
-
; wStatusFlags::
const_def
const STATUSFLAGS_POKEDEX_F ; 0
--- a/sram.asm
+++ b/sram.asm
@@ -6,6 +6,7 @@
SECTION "SRAM Bank 0", SRAM
sPartyMail::
+ table_width MAIL_STRUCT_LENGTH, sPartyMail
sPartyMon1Mail:: mailmsg sPartyMon1Mail
sPartyMon2Mail:: mailmsg sPartyMon2Mail
sPartyMon3Mail:: mailmsg sPartyMon3Mail
@@ -12,8 +13,10 @@
sPartyMon4Mail:: mailmsg sPartyMon4Mail
sPartyMon5Mail:: mailmsg sPartyMon5Mail
sPartyMon6Mail:: mailmsg sPartyMon6Mail
+ assert_table_length PARTY_LENGTH
sPartyMailBackup::
+ table_width MAIL_STRUCT_LENGTH, sPartyMailBackup
sPartyMon1MailBackup:: mailmsg sPartyMon1MailBackup
sPartyMon2MailBackup:: mailmsg sPartyMon2MailBackup
sPartyMon3MailBackup:: mailmsg sPartyMon3MailBackup
@@ -20,9 +23,11 @@
sPartyMon4MailBackup:: mailmsg sPartyMon4MailBackup
sPartyMon5MailBackup:: mailmsg sPartyMon5MailBackup
sPartyMon6MailBackup:: mailmsg sPartyMon6MailBackup
+ assert_table_length PARTY_LENGTH
sMailboxCount:: db
sMailboxes::
+ table_width MAIL_STRUCT_LENGTH, sMailboxes
sMailbox1:: mailmsg sMailbox1
sMailbox2:: mailmsg sMailbox2
sMailbox3:: mailmsg sMailbox3
@@ -33,9 +38,11 @@
sMailbox8:: mailmsg sMailbox8
sMailbox9:: mailmsg sMailbox9
sMailbox10:: mailmsg sMailbox10
+ assert_table_length MAILBOX_CAPACITY
sMailboxCountBackup:: db
sMailboxesBackup::
+ table_width MAIL_STRUCT_LENGTH, sMailboxesBackup
sMailbox1Backup:: mailmsg sMailbox1Backup
sMailbox2Backup:: mailmsg sMailbox2Backup
sMailbox3Backup:: mailmsg sMailbox3Backup
@@ -46,6 +53,7 @@
sMailbox8Backup:: mailmsg sMailbox8Backup
sMailbox9Backup:: mailmsg sMailbox9Backup
sMailbox10Backup:: mailmsg sMailbox10Backup
+ assert_table_length MAILBOX_CAPACITY
sMysteryGiftData::
sMysteryGiftItem:: db
@@ -145,6 +153,7 @@
SECTION "SRAM Hall of Fame", SRAM
sHallOfFame::
+ table_width HOF_LENGTH, sHallOfFame
sHallOfFame01:: hall_of_fame sHallOfFame01
sHallOfFame02:: hall_of_fame sHallOfFame02
sHallOfFame03:: hall_of_fame sHallOfFame03
@@ -175,6 +184,7 @@
sHallOfFame28:: hall_of_fame sHallOfFame28
sHallOfFame29:: hall_of_fame sHallOfFame29
sHallOfFame30:: hall_of_fame sHallOfFame30
+ assert_table_length NUM_HOF_TEAMS
sHallOfFameEnd::
--- a/wram.asm
+++ b/wram.asm
@@ -20,16 +20,17 @@
wMusicPlaying:: db
wAudio::
-
+ table_width CHANNEL_STRUCT_LENGTH, wAudio
wChannel1:: channel_struct wChannel1
wChannel2:: channel_struct wChannel2
wChannel3:: channel_struct wChannel3
wChannel4:: channel_struct wChannel4
-
+ assert_table_length NUM_MUSIC_CHANS
wChannel5:: channel_struct wChannel5
wChannel6:: channel_struct wChannel6
wChannel7:: channel_struct wChannel7
wChannel8:: channel_struct wChannel8
+ assert_table_length NUM_CHANNELS
ds 1
@@ -224,6 +225,7 @@
ds NUM_SPRITEANIMDICT_ENTRIES * 2
wSpriteAnimationStructs::
+ table_width SPRITEANIMSTRUCT_LENGTH, wSpriteAnimationStructs
; field 0: index
; fields 1-3: loaded from SpriteAnimSeqData
wSpriteAnim1:: sprite_anim_struct wSpriteAnim1
@@ -236,6 +238,7 @@
wSpriteAnim8:: sprite_anim_struct wSpriteAnim8
wSpriteAnim9:: sprite_anim_struct wSpriteAnim9
wSpriteAnim10:: sprite_anim_struct wSpriteAnim10
+ assert_table_length NUM_SPRITE_ANIM_STRUCTS
wSpriteAnimationStructsEnd::
NEXTU
@@ -322,6 +325,7 @@
SECTION "Sprites", WRAM0
wVirtualOAM::
+ table_width SPRITEOAMSTRUCT_LENGTH, wVirtualOAM
wVirtualOAMSprite00:: sprite_oam_struct wVirtualOAMSprite00
wVirtualOAMSprite01:: sprite_oam_struct wVirtualOAMSprite01
wVirtualOAMSprite02:: sprite_oam_struct wVirtualOAMSprite02
@@ -362,6 +366,7 @@
wVirtualOAMSprite37:: sprite_oam_struct wVirtualOAMSprite37
wVirtualOAMSprite38:: sprite_oam_struct wVirtualOAMSprite38
wVirtualOAMSprite39:: sprite_oam_struct wVirtualOAMSprite39
+ assert_table_length NUM_SPRITE_OAM_STRUCTS
wVirtualOAMEnd::
@@ -981,6 +986,7 @@
UNION
; link player data
wLinkPlayerData::
+ table_width PARTYMON_STRUCT_LENGTH, wLinkPlayerData
wLinkPlayerPartyMon1:: party_struct wLinkPlayerPartyMon1
wLinkPlayerPartyMon2:: party_struct wLinkPlayerPartyMon2
wLinkPlayerPartyMon3:: party_struct wLinkPlayerPartyMon3
@@ -987,6 +993,7 @@
wLinkPlayerPartyMon4:: party_struct wLinkPlayerPartyMon4
wLinkPlayerPartyMon5:: party_struct wLinkPlayerPartyMon5
wLinkPlayerPartyMon6:: party_struct wLinkPlayerPartyMon6
+ assert_table_length PARTY_LENGTH
wLinkPlayerPartyMonOTNames:: ds NAME_LENGTH * PARTY_LENGTH
wLinkPlayerPartyMonNicks:: ds MON_NAME_LENGTH * PARTY_LENGTH
@@ -993,6 +1000,7 @@
NEXTU
; time capsule party data
wTimeCapsulePlayerData::
+ table_width REDMON_STRUCT_LENGTH, wTimeCapsulePlayerData
wTimeCapsulePartyMon1:: red_party_struct wTimeCapsulePartyMon1
wTimeCapsulePartyMon2:: red_party_struct wTimeCapsulePartyMon2
wTimeCapsulePartyMon3:: red_party_struct wTimeCapsulePartyMon3
@@ -999,6 +1007,7 @@
wTimeCapsulePartyMon4:: red_party_struct wTimeCapsulePartyMon4
wTimeCapsulePartyMon5:: red_party_struct wTimeCapsulePartyMon5
wTimeCapsulePartyMon6:: red_party_struct wTimeCapsulePartyMon6
+ assert_table_length PARTY_LENGTH
wTimeCapsulePartyMonOTNames:: ds NAME_LENGTH * PARTY_LENGTH
wTimeCapsulePartyMonNicks:: ds MON_NAME_LENGTH * PARTY_LENGTH
@@ -2558,6 +2567,7 @@
UNION
; ot party mons
wOTPartyMons::
+ table_width PARTYMON_STRUCT_LENGTH, wOTPartyMons
wOTPartyMon1:: party_struct wOTPartyMon1
wOTPartyMon2:: party_struct wOTPartyMon2
wOTPartyMon3:: party_struct wOTPartyMon3
@@ -2564,6 +2574,7 @@
wOTPartyMon4:: party_struct wOTPartyMon4
wOTPartyMon5:: party_struct wOTPartyMon5
wOTPartyMon6:: party_struct wOTPartyMon6
+ assert_table_length PARTY_LENGTH
wOTPartyMonsEnd::
wOTPartyMonOT:: ds NAME_LENGTH * PARTY_LENGTH
@@ -2719,6 +2730,7 @@
wFollowMovementQueue:: ds 5
wObjectStructs::
+ table_width OBJECT_LENGTH, wObjectStructs
wPlayerStruct:: object_struct wPlayer
wObject1Struct:: object_struct wObject1
wObject2Struct:: object_struct wObject2
@@ -2732,6 +2744,7 @@
wObject10Struct:: object_struct wObject10
wObject11Struct:: object_struct wObject11
wObject12Struct:: object_struct wObject12
+ assert_table_length NUM_OBJECT_STRUCTS
wCmdQueue:: ds CMDQUEUE_CAPACITY * CMDQUEUE_ENTRY_SIZE
@@ -2738,6 +2751,7 @@
ds 40
wMapObjects::
+ table_width MAPOBJECT_LENGTH, wMapObjects
wPlayerObject:: map_object wPlayer
wMap1Object:: map_object wMap1
wMap2Object:: map_object wMap2
@@ -2754,6 +2768,7 @@
wMap13Object:: map_object wMap13
wMap14Object:: map_object wMap14
wMap15Object:: map_object wMap15
+ assert_table_length NUM_OBJECTS
wObjectMasks:: ds NUM_OBJECTS
@@ -3117,6 +3132,7 @@
wPartyEnd:: db ; older code doesn't check wPartyCount
wPartyMons::
+ table_width PARTYMON_STRUCT_LENGTH, wPartyMons
wPartyMon1:: party_struct wPartyMon1
wPartyMon2:: party_struct wPartyMon2
wPartyMon3:: party_struct wPartyMon3
@@ -3123,6 +3139,7 @@
wPartyMon4:: party_struct wPartyMon4
wPartyMon5:: party_struct wPartyMon5
wPartyMon6:: party_struct wPartyMon6
+ assert_table_length PARTY_LENGTH
wPartyMonOT:: ds NAME_LENGTH * PARTY_LENGTH
@@ -3343,6 +3360,7 @@
ds NUM_BATTLEANIMTILEDICT_ENTRIES * 2
wActiveAnimObjects::
+ table_width BATTLEANIMSTRUCT_LENGTH, wActiveAnimObjects
wAnimObject01:: battle_anim_struct wAnimObject01
wAnimObject02:: battle_anim_struct wAnimObject02
wAnimObject03:: battle_anim_struct wAnimObject03
@@ -3353,13 +3371,16 @@
wAnimObject08:: battle_anim_struct wAnimObject08
wAnimObject09:: battle_anim_struct wAnimObject09
wAnimObject10:: battle_anim_struct wAnimObject10
+ assert_table_length NUM_ANIM_OBJECTS
wActiveBGEffects::
+ table_width BG_EFFECT_STRUCT_LENGTH, wActiveBGEffects
wBGEffect1:: battle_bg_effect wBGEffect1
wBGEffect2:: battle_bg_effect wBGEffect2
wBGEffect3:: battle_bg_effect wBGEffect3
wBGEffect4:: battle_bg_effect wBGEffect4
wBGEffect5:: battle_bg_effect wBGEffect5
+ assert_table_length NUM_BG_EFFECTS
wLastAnimObjectIndex:: db