2017-12-12 08:17:52 -06:00
|
|
|
import os
|
2019-12-09 19:27:56 +01:00
|
|
|
import re
|
2017-12-12 08:17:52 -06:00
|
|
|
import time
|
|
|
|
import logging
|
|
|
|
|
2019-12-09 19:27:56 +01:00
|
|
|
from Utils import output_path, parse_names_string
|
2017-12-17 00:25:46 -05:00
|
|
|
from Rom import LocalRom, Sprite, apply_rom_settings
|
2017-12-12 08:17:52 -06:00
|
|
|
|
|
|
|
|
|
|
|
def adjust(args):
|
2019-10-16 08:20:28 +02:00
|
|
|
start = time.process_time()
|
2017-12-12 08:17:52 -06:00
|
|
|
logger = logging.getLogger('')
|
|
|
|
logger.info('Patching ROM.')
|
|
|
|
|
|
|
|
if args.sprite is not None:
|
2017-12-17 00:25:46 -05:00
|
|
|
if isinstance(args.sprite, Sprite):
|
2017-12-16 19:13:21 -05:00
|
|
|
sprite = args.sprite
|
|
|
|
else:
|
|
|
|
sprite = Sprite(args.sprite)
|
2017-12-12 08:17:52 -06:00
|
|
|
else:
|
|
|
|
sprite = None
|
|
|
|
|
2018-01-06 21:06:34 -06:00
|
|
|
outfilebase = os.path.basename(args.rom)[:-4] + '_adjusted'
|
2017-12-12 08:17:52 -06:00
|
|
|
|
2019-04-18 11:23:24 +02:00
|
|
|
if os.stat(args.rom).st_size in (0x200000, 0x400000) and os.path.splitext(args.rom)[-1].lower() == '.sfc':
|
2017-12-13 23:21:43 -05:00
|
|
|
rom = LocalRom(args.rom, False)
|
|
|
|
else:
|
|
|
|
raise RuntimeError('Provided Rom is not a valid Link to the Past Randomizer Rom. Please provide one for adjusting.')
|
|
|
|
|
2019-12-09 19:27:56 +01:00
|
|
|
apply_rom_settings(rom, args.heartbeep, args.heartcolor, args.quickswap, args.fastmenu, args.disablemusic, sprite, parse_names_string(args.names))
|
2017-12-12 08:17:52 -06:00
|
|
|
|
|
|
|
rom.write_to_file(output_path('%s.sfc' % outfilebase))
|
|
|
|
|
|
|
|
logger.info('Done. Enjoy.')
|
2019-10-16 08:20:28 +02:00
|
|
|
logger.debug('Total Time: %s', time.process_time() - start)
|
2017-12-12 08:17:52 -06:00
|
|
|
|
2017-12-13 23:21:43 -05:00
|
|
|
return args
|