| 
									
										
										
										
											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 |