2017-12-12 14:17:52 +00:00
|
|
|
import os
|
|
|
|
import time
|
|
|
|
import logging
|
|
|
|
|
2017-12-17 05:25:46 +00:00
|
|
|
from Utils import output_path
|
2020-01-09 01:30:00 +00:00
|
|
|
from Rom import LocalRom, apply_rom_settings
|
2017-12-12 14:17:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
def adjust(args):
|
2020-01-02 01:38:26 +00:00
|
|
|
start = time.perf_counter()
|
2020-03-17 18:43:06 +00:00
|
|
|
logger = logging.getLogger('Adjuster')
|
2017-12-12 14:17:52 +00:00
|
|
|
logger.info('Patching ROM.')
|
2020-10-24 00:44:27 +00:00
|
|
|
vanillaRom = args.baserom
|
2020-07-10 19:39:32 +00:00
|
|
|
if os.path.splitext(args.rom)[-1].lower() == '.bmbp':
|
|
|
|
import Patch
|
|
|
|
meta, args.rom = Patch.create_rom_file(args.rom)
|
|
|
|
|
2019-04-18 09:23:24 +00:00
|
|
|
if os.stat(args.rom).st_size in (0x200000, 0x400000) and os.path.splitext(args.rom)[-1].lower() == '.sfc':
|
2020-10-24 00:44:27 +00:00
|
|
|
rom = LocalRom(args.rom, patch=False, vanillaRom=vanillaRom)
|
2017-12-14 04:21:43 +00:00
|
|
|
else:
|
2020-04-26 13:14:30 +00:00
|
|
|
raise RuntimeError(
|
|
|
|
'Provided Rom is not a valid Link to the Past Randomizer Rom. Please provide one for adjusting.')
|
2020-10-24 00:44:27 +00:00
|
|
|
palettes_options={}
|
|
|
|
palettes_options['dungeon']=args.uw_palettes
|
|
|
|
|
|
|
|
palettes_options['overworld']=args.ow_palettes
|
|
|
|
palettes_options['hud']=args.hud_palettes
|
|
|
|
palettes_options['sword']=args.sword_palettes
|
|
|
|
palettes_options['shield']=args.shield_palettes
|
2020-12-04 22:52:03 +00:00
|
|
|
# palettes_options['link']=args.link_palettesvera
|
2020-10-24 00:44:27 +00:00
|
|
|
|
2020-04-26 13:14:30 +00:00
|
|
|
apply_rom_settings(rom, args.heartbeep, args.heartcolor, args.quickswap, args.fastmenu, args.disablemusic,
|
2020-10-24 00:44:27 +00:00
|
|
|
args.sprite, palettes_options)
|
2020-04-26 13:14:30 +00:00
|
|
|
path = output_path(f'{os.path.basename(args.rom)[:-4]}_adjusted.sfc')
|
|
|
|
rom.write_to_file(path)
|
2017-12-12 14:17:52 +00:00
|
|
|
|
|
|
|
logger.info('Done. Enjoy.')
|
2020-01-02 01:38:26 +00:00
|
|
|
logger.debug('Total Time: %s', time.perf_counter() - start)
|
2017-12-12 14:17:52 +00:00
|
|
|
|
2020-04-26 13:14:30 +00:00
|
|
|
return args, path
|