mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	OoT: No Logic modifications
NL now uses the glitchless world graph, which enables entrance randomizer NL forces all logic tricks on, progression balancing off, minimal accessibility
This commit is contained in:
		| @@ -122,7 +122,7 @@ def create_dungeons(ootworld): | ||||
|         hint = dungeon_info['hint'] if 'hint' in dungeon_info else name | ||||
|         font_color = dungeon_info['font_color'] if 'font_color' in dungeon_info else 'White' | ||||
|          | ||||
|         if ootworld.logic_rules == 'glitchless': | ||||
|         if ootworld.logic_rules == 'glitchless' or ootworld.logic_rules == 'no_logic':  # ER + NL | ||||
|             if not ootworld.dungeon_mq[name]: | ||||
|                 dungeon_json = os.path.join(data_path('World'), name + '.json') | ||||
|             else: | ||||
|   | ||||
| @@ -170,6 +170,7 @@ class OOTWorld(World): | ||||
|         self.dungeon_mq = {item['name']: (item in mq_dungeons) for item in dungeon_table} | ||||
|  | ||||
|         # Determine tricks in logic | ||||
|         if self.logic_rules == 'glitchless': | ||||
|             for trick in self.logic_tricks: | ||||
|                 normalized_name = trick.casefold() | ||||
|                 if normalized_name in normalized_name_tricks: | ||||
| @@ -177,6 +178,13 @@ class OOTWorld(World): | ||||
|                 else: | ||||
|                     raise Exception(f'Unknown OOT logic trick for player {self.player}: {trick}') | ||||
|  | ||||
|         # No Logic forces all tricks on, prog balancing off and beatable-only | ||||
|         elif self.logic_rules == 'no_logic': | ||||
|             self.world.progression_balancing[self.player].value = False | ||||
|             self.world.accessibility[self.player] = self.world.accessibility[self.player].from_text("minimal") | ||||
|             for trick in normalized_name_tricks.values(): | ||||
|                 setattr(self, trick['name'], True) | ||||
|  | ||||
|         # Not implemented for now, but needed to placate the generator. Remove as they are implemented | ||||
|         self.mq_dungeons_random = False  # this will be a deprecated option later | ||||
|         self.ocarina_songs = False  # just need to pull in the OcarinaSongs module | ||||
| @@ -298,7 +306,6 @@ class OOTWorld(World): | ||||
|                         continue | ||||
|                     new_location.parent_region = new_region | ||||
|                     new_location.rule_string = rule | ||||
|                     if self.world.logic_rules != 'none': | ||||
|                     self.parser.parse_spot_rule(new_location) | ||||
|                     if new_location.never: | ||||
|                         # We still need to fill the location even if ALR is off. | ||||
| @@ -311,7 +318,6 @@ class OOTWorld(World): | ||||
|                     lname = '%s from %s' % (event, new_region.name) | ||||
|                     new_location = OOTLocation(self.player, lname, type='Event', parent=new_region) | ||||
|                     new_location.rule_string = rule | ||||
|                     if self.world.logic_rules != 'none': | ||||
|                     self.parser.parse_spot_rule(new_location) | ||||
|                     if new_location.never: | ||||
|                         logger.debug('Dropping unreachable event: %s', new_location.name) | ||||
| @@ -436,7 +442,7 @@ class OOTWorld(World): | ||||
|         return item | ||||
|  | ||||
|     def create_regions(self):  # create and link regions | ||||
|         if self.logic_rules == 'glitchless': | ||||
|         if self.logic_rules == 'glitchless' or self.logic_rules == 'no_logic':  # enables ER + NL | ||||
|             world_type = 'World' | ||||
|         else: | ||||
|             world_type = 'Glitched World' | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 espeon65536
					espeon65536