2018-01-01 13:11:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#!/usr/bin/env python3  
						 
					
						
							
								
									
										
										
										
											2017-12-17 00:25:46 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  argparse  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  hashlib  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  logging  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  os  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  random  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  time  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  sys  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 14:57:12 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  BaseClasses  import  World  
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								from  Regions  import  create_regions  
						 
					
						
							
								
									
										
										
										
											2017-06-03 17:09:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  EntranceShuffle  import  link_entrances ,  connect_entrance ,  connect_two_way ,  connect_exit  
						 
					
						
							
								
									
										
										
										
											2019-12-09 19:27:56 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  Rom  import  patch_rom ,  LocalRom ,  Sprite ,  write_string_to_rom ,  apply_rom_settings  
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								from  Rules  import  set_rules  
						 
					
						
							
								
									
										
										
										
											2017-10-15 12:16:07 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  Dungeons  import  create_dungeons  
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								from  Items  import  ItemFactory  
						 
					
						
							
								
									
										
										
										
											2018-01-04 01:06:22 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  ItemList  import  difficulties  
						 
					
						
							
								
									
										
										
										
											2017-06-17 14:57:12 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  Main  import  create_playthrough  
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 13:16:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								__version__  =  ' 0.2-dev '  
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-12-17 00:25:46 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  main ( args ) :  
						 
					
						
							
								
									
										
										
										
											2019-10-16 08:20:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    start_time  =  time . process_time ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # initialize the world 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-17 15:55:53 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    world  =  World ( 1 ,  ' vanilla ' ,  ' noglitches ' ,  ' standard ' ,  ' normal ' ,  ' none ' ,  ' on ' ,  ' ganon ' ,  ' freshness ' ,  False ,  False ,  False ,  args . quickswap ,  args . fastmenu ,  args . disablemusic ,  False ,  False ,  False ,  None ,  False ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    logger  =  logging . getLogger ( ' ' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    hasher  =  hashlib . md5 ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    with  open ( args . plando ,  ' rb ' )  as  plandofile : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        buf  =  plandofile . read ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        hasher . update ( buf ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    world . seed  =  int ( hasher . hexdigest ( ) ,  16 )  %  1000000000 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    random . seed ( world . seed ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-12-17 00:25:46 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    logger . info ( ' ALttP Plandomizer Version  %s   -  Seed:  %s \n \n ' ,  __version__ ,  args . plando ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-16 17:46:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    world . difficulty_requirements [ 1 ]  =  difficulties [ world . difficulty [ 1 ] ] 
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 01:06:22 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    create_regions ( world ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    create_dungeons ( world ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    link_entrances ( world ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    logger . info ( ' Calculating Access Rules. ' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    set_rules ( world ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    logger . info ( ' Fill the world. ' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 13:16:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    text_patches  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-07-21 05:37:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fill_world ( world ,  args . plando ,  text_patches ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  world . get_entrance ( ' Dam ' ,  1 ) . connected_region . name  !=  ' Dam '  or  world . get_entrance ( ' Swamp Palace ' ,  1 ) . connected_region . name  !=  ' Swamp Palace (Entrance) ' : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        world . swamp_patch_required [ 1 ]  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 13:16:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    logger . info ( ' Calculating playthrough. ' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-06-03 17:09:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    try : 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-21 05:37:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        create_playthrough ( world ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-03 17:09:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    except  RuntimeError : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  args . ignore_unsolvable : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            pass 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            raise 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    logger . info ( ' Patching ROM. ' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  args . sprite  is  not  None : 
							 
						 
					
						
							
								
									
										
										
										
											2017-12-17 17:30:50 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        sprite  =  Sprite ( args . sprite ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        sprite  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-07-14 14:37:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    rom  =  LocalRom ( args . rom ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-09 19:27:56 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    patch_rom ( world ,  1 ,  rom ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    apply_rom_settings ( rom ,  args . heartbeep ,  args . heartcolor ,  world . quickswap ,  world . fastmenu ,  world . disable_music ,  sprite ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 13:16:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    for  textname ,  texttype ,  text  in  text_patches : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  texttype  ==  ' text ' : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            write_string_to_rom ( rom ,  textname ,  text ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-12-17 00:25:46 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        #elif texttype == 'credit': 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        #    write_credits_string_to_rom(rom, textname, text) 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 13:16:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    outfilebase  =  ' Plando_ %s _ %s '  %  ( os . path . splitext ( os . path . basename ( args . plando ) ) [ 0 ] ,  world . seed ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-07-14 14:37:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    rom . write_to_file ( ' %s .sfc '  %  outfilebase ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    if  args . create_spoiler : 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-21 05:37:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        world . spoiler . to_file ( ' %s _Spoiler.txt '  %  outfilebase ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    logger . info ( ' Done. Enjoy. ' ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-16 08:20:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    logger . debug ( ' Total Time:  %s ' ,  time . process_time ( )  -  start_time ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  world 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 13:16:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  fill_world ( world ,  plando ,  text_patches ) :  
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    mm_medallion  =  ' Ether ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    tr_medallion  =  ' Quake ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    logger  =  logging . getLogger ( ' ' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    with  open ( plando ,  ' r ' )  as  plandofile : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  line  in  plandofile . readlines ( ) : 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 13:16:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  line . startswith ( ' # ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                continue 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								            if  ' : '  in  line : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                line  =  line . lstrip ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  line . startswith ( ' ! ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  line . startswith ( ' !mm_medallion ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  medallionstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        mm_medallion  =  medallionstr . strip ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !tr_medallion ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  medallionstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        tr_medallion  =  medallionstr . strip ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !mode ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  modestr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-16 16:54:46 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        world . mode  =  { 1 :  modestr . strip ( ) } 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !logic ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  logicstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-16 13:26:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        world . logic  =  { 1 :  logicstr . strip ( ) } 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !goal ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  goalstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-16 15:27:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        world . goal  =  { 1 :  goalstr . strip ( ) } 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 13:16:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !light_cone_sewers ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  sewerstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-16 16:54:46 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        world . sewer_light_cone  =  { 1 :  sewerstr . strip ( ) . lower ( )  ==  ' true ' } 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 13:16:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !light_cone_lw ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  lwconestr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        world . light_world_light_cone  =  lwconestr . strip ( ) . lower ( )  ==  ' true ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !light_cone_dw ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  dwconestr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        world . dark_world_light_cone  =  dwconestr . strip ( ) . lower ( )  ==  ' true ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !fix_trock_doors ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  trdstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-16 16:54:46 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        world . fix_trock_doors  =  { 1 :  trdstr . strip ( ) . lower ( )  ==  ' true ' } 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-24 19:11:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !fix_trock_exit ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  trfstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-16 18:24:34 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        world . fix_trock_exit  =  { 1 :  trfstr . strip ( ) . lower ( )  ==  ' true ' } 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-14 16:11:07 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !fix_gtower_exit ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  gtfstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        world . fix_gtower_exit  =  gtfstr . strip ( ) . lower ( )  ==  ' true ' 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-24 19:11:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !fix_pod_exit ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  podestr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-16 18:24:34 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        world . fix_palaceofdarkness_exit  =  { 1 :  podestr . strip ( ) . lower ( )  ==  ' true ' } 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-24 19:11:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !fix_skullwoods_exit ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  swestr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-16 18:24:34 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        world . fix_skullwoods_exit  =  { 1 :  swestr . strip ( ) . lower ( )  ==  ' true ' } 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-24 19:11:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !check_beatable_only ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  chkbtstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        world . check_beatable_only  =  chkbtstr . strip ( ) . lower ( )  ==  ' true ' 
							 
						 
					
						
							
								
									
										
										
										
											2017-08-01 19:08:46 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !ganon_death_pyramid_respawn ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  gnpstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        world . ganon_at_pyramid  =  gnpstr . strip ( ) . lower ( )  ==  ' true ' 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-24 19:11:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !save_quit_boss ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        _ ,  sqbstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        world . save_and_quite_from_boss  =  sqbstr . strip ( ) . lower ( )  ==  ' true ' 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 13:16:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  line . startswith ( ' !text_ ' ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        textname ,  text  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        text_patches . append ( [ textname . lstrip ( ' !text_ ' ) . strip ( ) ,  ' text ' ,  text . strip ( ) ] ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-19 16:00:26 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    #temporarilly removed. New credits system not ready to handle this. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    #elif line.startswith('!credits_'): 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    #    textname, text = line.split(':', 1) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    #    text_patches.append([textname.lstrip('!credits_').strip(), 'credits', text.strip()]) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                    continue 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                locationstr ,  itemstr  =  line . split ( ' : ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                location  =  world . get_location ( locationstr . strip ( ) ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                if  location  is  None : 
							 
						 
					
						
							
								
									
										
										
										
											2017-12-17 00:25:46 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    logger . warning ( ' Unknown location:  %s ' ,  locationstr ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                    continue 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    item  =  ItemFactory ( itemstr . strip ( ) ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                    if  item  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        world . push_item ( location ,  item ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 22:37:52 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  item . smallkey  or  item . bigkey : 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 14:57:12 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        location . event  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-03 17:09:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  ' <=> '  in  line : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                entrance ,  exit  =  line . split ( ' <=> ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                connect_two_way ( world ,  entrance . strip ( ) ,  exit . strip ( ) ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-03 17:09:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  ' => '  in  line : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                entrance ,  exit  =  line . split ( ' => ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                connect_entrance ( world ,  entrance . strip ( ) ,  exit . strip ( ) ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-03 17:09:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  ' <= '  in  line : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                entrance ,  exit  =  line . split ( ' <= ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                connect_exit ( world ,  exit . strip ( ) ,  entrance . strip ( ) ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    world . required_medallions [ 1 ]  =  ( mm_medallion ,  tr_medallion ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 14:57:12 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # set up Agahnim Events 
							 
						 
					
						
							
								
									
										
										
										
											2019-04-18 11:23:24 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    world . get_location ( ' Agahnim 1 ' ,  1 ) . event  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    world . get_location ( ' Agahnim 1 ' ,  1 ) . item  =  ItemFactory ( ' Beat Agahnim 1 ' ,  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    world . get_location ( ' Agahnim 2 ' ,  1 ) . event  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    world . get_location ( ' Agahnim 2 ' ,  1 ) . item  =  ItemFactory ( ' Beat Agahnim 2 ' ,  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-17 14:57:12 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-12-17 00:25:46 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  start ( ) :  
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    parser  =  argparse . ArgumentParser ( formatter_class = argparse . ArgumentDefaultsHelpFormatter ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    parser . add_argument ( ' --create_spoiler ' ,  help = ' Output a Spoiler File ' ,  action = ' store_true ' ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-03 17:09:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    parser . add_argument ( ' --ignore_unsolvable ' ,  help = ' Do not abort if seed is deemed unsolvable. ' ,  action = ' store_true ' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    parser . add_argument ( ' --rom ' ,  default = ' Zelda no Densetsu - Kamigami no Triforce (Japan).sfc ' ,  help = ' Path to an ALttP JAP(1.0) rom to use as a base. ' ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    parser . add_argument ( ' --loglevel ' ,  default = ' info ' ,  const = ' info ' ,  nargs = ' ? ' ,  choices = [ ' error ' ,  ' info ' ,  ' warning ' ,  ' debug ' ] ,  help = ' Select level of logging for output. ' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    parser . add_argument ( ' --seed ' ,  help = ' Define seed number to generate. ' ,  type = int ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-01-05 16:53:29 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    parser . add_argument ( ' --fastmenu ' ,  default = ' normal ' ,  const = ' normal ' ,  nargs = ' ? ' ,  choices = [ ' normal ' ,  ' instant ' ,  ' double ' ,  ' triple ' ,  ' quadruple ' ,  ' half ' ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        help = ''' \
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                             Select  the  rate  at  which  the  menu  opens  and  closes . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                             ( default :  % ( default ) s ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                             ''' ) 
 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    parser . add_argument ( ' --quickswap ' ,  help = ' Enable quick item swapping with L and R. ' ,  action = ' store_true ' ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-28 04:54:14 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    parser . add_argument ( ' --disablemusic ' ,  help = ' Disables game music. ' ,  action = ' store_true ' ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    parser . add_argument ( ' --heartbeep ' ,  default = ' normal ' ,  const = ' normal ' ,  nargs = ' ? ' ,  choices = [ ' normal ' ,  ' half ' ,  ' quarter ' ,  ' off ' ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        help = ' Select the rate at which the heart beep sound is played at low health. ' ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-03-03 12:42:46 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    parser . add_argument ( ' --heartcolor ' ,  default = ' red ' ,  const = ' red ' ,  nargs = ' ? ' ,  choices = [ ' red ' ,  ' blue ' ,  ' green ' ,  ' yellow ' ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        help = ' Select the color of Link \' s heart meter. (default:  %(default)s ) ' ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    parser . add_argument ( ' --sprite ' ,  help = ' Path to a sprite sheet to use for Link. Needs to be in binary format and have a length of 0x7000 (28672) bytes. ' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    parser . add_argument ( ' --plando ' ,  help = ' Filled out template to use for setting up the rom. ' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    args  =  parser . parse_args ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # ToDo: Validate files further than mere existance 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  not  os . path . isfile ( args . rom ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        input ( ' Could not find valid base rom for patching at expected path  %s . Please run with -h to see help for further information.  \n Press Enter to exit. '  %  args . rom ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-19 16:00:26 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        sys . exit ( 1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    if  not  os . path . isfile ( args . plando ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        input ( ' Could not find Plandomizer distribution at expected path  %s . Please run with -h to see help for further information.  \n Press Enter to exit. '  %  args . plando ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-19 16:00:26 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        sys . exit ( 1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    if  args . sprite  is  not  None  and  not  os . path . isfile ( args . rom ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        input ( ' Could not find link sprite sheet at given location.  \n Press Enter to exit. '  %  args . sprite ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-19 16:00:26 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        sys . exit ( 1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-05-26 18:40:48 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # set up logger 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    loglevel  =  { ' error ' :  logging . ERROR ,  ' info ' :  logging . INFO ,  ' warning ' :  logging . WARNING ,  ' debug ' :  logging . DEBUG } [ args . loglevel ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    logging . basicConfig ( format = ' %(message)s ' ,  level = loglevel ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    main ( args = args ) 
							 
						 
					
						
							
								
									
										
										
										
											2017-12-17 00:25:46 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								if  __name__  ==  ' __main__ ' :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    start ( )