Update used_space.py and mapreader.py tools for rgbds v0.4.0.

This commit is contained in:
entrpntr 2020-05-19 22:36:41 -04:00
parent f1513ae8ad
commit c37e8a65d8
3 changed files with 11 additions and 6 deletions

3
.gitignore vendored
View File

@ -29,6 +29,9 @@
baserom.txt baserom.txt
pokecrystal.txt pokecrystal.txt
# used_space.py
used_space.png
# for vim configuration # for vim configuration
# url: http://www.vim.org/scripts/script.php?script_id=441 # url: http://www.vim.org/scripts/script.php?script_id=441
.lvimrc .lvimrc

View File

@ -38,10 +38,11 @@ class MapReader:
bank_types = { bank_types = {
'HRAM' : { 'size': 0x80, 'banked': False, }, 'HRAM' : { 'size': 0x80, 'banked': False, },
'OAM' : { 'size': 0xA0, 'banked': False, }, 'OAM' : { 'size': 0xA0, 'banked': False, },
'ROM Bank' : { 'size': 0x4000, 'banked': True, }, 'ROM0 bank': { 'size': 0x4000, 'banked': True, },
'SRAM Bank': { 'size': 0x2000, 'banked': True, }, 'ROMX bank': { 'size': 0x4000, 'banked': True, },
'VRAM Bank': { 'size': 0x1000, 'banked': True, }, 'SRAM bank': { 'size': 0x2000, 'banked': True, },
'WRAM Bank': { 'size': 0x2000, 'banked': True, }, 'VRAM bank': { 'size': 0x1000, 'banked': True, },
'WRAM bank': { 'size': 0x2000, 'banked': True, },
} }
# FSM states # FSM states
@ -52,7 +53,7 @@ class MapReader:
# $506D = TypeMatchups # $506D = TypeMatchups
section_data_regex = re.compile('\$([0-9A-Fa-f]{4}) = (.*)') section_data_regex = re.compile('\$([0-9A-Fa-f]{4}) = (.*)')
# $3ED2 bytes # $3ED2 bytes
slack_regex = re.compile('\$([0-9A-Fa-f]{4}) bytes') slack_regex = re.compile('\$([0-9A-Fa-f]{4}) bytes?')
def __init__(self, *args, **kwargs): def __init__(self, *args, **kwargs):
self.__dict__.update(kwargs) self.__dict__.update(kwargs)

View File

@ -38,7 +38,8 @@ def main():
default_bank_data = {'sections': [], 'used': 0, 'slack': bank_size} default_bank_data = {'sections': [], 'used': 0, 'slack': bank_size}
for bank in range(num_banks): for bank in range(num_banks):
hits = [0] * pixels_per_bank hits = [0] * pixels_per_bank
data = r.bank_data['ROM Bank'].get(bank, default_bank_data) bank_data = r.bank_data['ROM0 bank'] if bank == 0 else r.bank_data['ROMX bank']
data = bank_data.get(bank, default_bank_data)
for s in data['sections']: for s in data['sections']:
beg = s['beg'] & bank_mask beg = s['beg'] & bank_mask
end = s['end'] & bank_mask end = s['end'] & bank_mask