rules for superbunny in TR/Hera
This commit is contained in:
@@ -530,6 +530,9 @@ class CollectionState(object):
|
|||||||
rules.append(self.has_Pearl(player))
|
rules.append(self.has_Pearl(player))
|
||||||
return all(rules)
|
return all(rules)
|
||||||
|
|
||||||
|
def can_superbunny_mirror_with_sword(self, player):
|
||||||
|
return self.has_Mirror(player) and self.has_sword(player)
|
||||||
|
|
||||||
def collect(self, item, event=False, location=None):
|
def collect(self, item, event=False, location=None):
|
||||||
if location:
|
if location:
|
||||||
self.locations_checked.add(location)
|
self.locations_checked.add(location)
|
||||||
|
|||||||
43
Rules.py
43
Rules.py
@@ -985,13 +985,12 @@ def overworld_glitches_rules(world, player):
|
|||||||
set_rule(world.get_entrance(clip_spot, player), lambda state: state.has_Mirror(player))
|
set_rule(world.get_entrance(clip_spot, player), lambda state: state.has_Mirror(player))
|
||||||
|
|
||||||
# Locations that you can superbunny mirror into, but need a sword to clear.
|
# Locations that you can superbunny mirror into, but need a sword to clear.
|
||||||
superbunny_mirror_weapon = lambda state: state.has_Mirror(player) and state.has_sword(player)
|
|
||||||
mini_moldorm_cave = world.get_region('Mini Moldorm Cave', player)
|
mini_moldorm_cave = world.get_region('Mini Moldorm Cave', player)
|
||||||
for superbunny_mirror_weapon_region in OWGSets.get_sword_required_superbunny_mirror_regions():
|
for superbunny_mirror_weapon_region in OWGSets.get_sword_required_superbunny_mirror_regions():
|
||||||
region = world.get_region(superbunny_mirror_weapon_region, player)
|
region = world.get_region(superbunny_mirror_weapon_region, player)
|
||||||
if check_is_dark_world(region):
|
if check_is_dark_world(region):
|
||||||
for spot in region.locations:
|
for spot in region.locations:
|
||||||
add_rule(world.get_location(spot, player), superbunny_mirror_weapon, 'or')
|
add_rule(world.get_location(spot, player), lambda state: state.can_superbunny_mirror_with_sword(player), 'or')
|
||||||
|
|
||||||
# Regions that require the boots and some other stuff.
|
# Regions that require the boots and some other stuff.
|
||||||
if world.mode != 'inverted':
|
if world.mode != 'inverted':
|
||||||
@@ -1576,13 +1575,19 @@ def set_bunny_rules(world, player):
|
|||||||
def get_rule_to_add(region, location = None):
|
def get_rule_to_add(region, location = None):
|
||||||
# In OWG, a location can potentially be superbunny-mirror accessible or
|
# In OWG, a location can potentially be superbunny-mirror accessible or
|
||||||
# bunny revival accessible.
|
# bunny revival accessible.
|
||||||
if world.logic == 'owglitches' and not any([
|
if world.logic == 'owglitches':
|
||||||
location in OWGSets.get_superbunny_accessible_locations() and region.name not in OWGSets.get_invalid_mirror_bunny_entrances_dw(),
|
if region.name == 'Tower of Hera (Bottom)' and region.name not in OWGSets.get_invalid_mirror_bunny_entrances_dw():
|
||||||
region.type == RegionType.Dungeon and region.name != 'Swamp Palace (Entrance)',
|
return lambda state: state.can_superbunny_mirror_with_sword(player) or state.has_Pearl(player)
|
||||||
not region.is_light_world]):
|
if region.name == 'Turtle Rock (Entrance)' and region.name not in OWGSets.get_invalid_mirror_bunny_entrances_dw():
|
||||||
return lambda state: state.has_Pearl(player)
|
return lambda state: state.has_Mirror(player) or state.has_Pearl(player)
|
||||||
elif world.logic != 'owglitches' and not region.is_light_world:
|
if not any([
|
||||||
return lambda state: state.has_Pearl(player)
|
location in OWGSets.get_superbunny_accessible_locations() and region.name not in OWGSets.get_invalid_mirror_bunny_entrances_dw(),
|
||||||
|
region.type == RegionType.Dungeon and region.name != 'Swamp Palace (Entrance)',
|
||||||
|
not region.is_dark_world]):
|
||||||
|
return lambda state: state.has_Pearl(player)
|
||||||
|
else:
|
||||||
|
if not region.is_dark_world:
|
||||||
|
return lambda state: state.has_Pearl(player)
|
||||||
# in this case we are mixed region.
|
# in this case we are mixed region.
|
||||||
# we collect possible options.
|
# we collect possible options.
|
||||||
|
|
||||||
@@ -1664,13 +1669,19 @@ def set_inverted_bunny_rules(world, player):
|
|||||||
def get_rule_to_add(region, location = None):
|
def get_rule_to_add(region, location = None):
|
||||||
# In OWG, a location can potentially be superbunny-mirror accessible or
|
# In OWG, a location can potentially be superbunny-mirror accessible or
|
||||||
# bunny revival accessible.
|
# bunny revival accessible.
|
||||||
if world.logic == 'owglitches' and not any([
|
if world.logic == 'owglitches':
|
||||||
location in OWGSets.get_superbunny_accessible_locations() and region.name not in OWGSets.get_invalid_mirror_bunny_entrances_dw(),
|
if region.name == 'Tower of Hera (Bottom)' and region.name not in OWGSets.get_invalid_mirror_bunny_entrances_dw():
|
||||||
region.type == RegionType.Dungeon and region.name != 'Swamp Palace (Entrance)',
|
return lambda state: state.can_superbunny_mirror_with_sword(player) or state.has_Pearl(player)
|
||||||
not region.is_dark_world]):
|
if region.name == 'Turtle Rock (Entrance)' and region.name not in OWGSets.get_invalid_mirror_bunny_entrances_dw():
|
||||||
return lambda state: state.has_Pearl(player)
|
return lambda state: state.has_Mirror(player) or state.has_Pearl(player)
|
||||||
elif world.logic != 'owglitches' and not region.is_dark_world:
|
if not any([
|
||||||
return lambda state: state.has_Pearl(player)
|
location in OWGSets.get_superbunny_accessible_locations() and region.name not in OWGSets.get_invalid_mirror_bunny_entrances_dw(),
|
||||||
|
region.type == RegionType.Dungeon and region.name != 'Swamp Palace (Entrance)',
|
||||||
|
not region.is_dark_world]):
|
||||||
|
return lambda state: state.has_Pearl(player)
|
||||||
|
else:
|
||||||
|
if not region.is_dark_world:
|
||||||
|
return lambda state: state.has_Pearl(player)
|
||||||
# in this case we are mixed region.
|
# in this case we are mixed region.
|
||||||
# we collect possible options.
|
# we collect possible options.
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user