[RoR2] Classic mode logic fix (#1775)
This commit is contained in:
parent
41b59488e3
commit
91b60f2e21
|
@ -67,20 +67,20 @@ def set_rules(multiworld: MultiWorld, player: int) -> None:
|
||||||
if multiworld.goal[player] == "classic":
|
if multiworld.goal[player] == "classic":
|
||||||
# classic mode
|
# classic mode
|
||||||
if divisions:
|
if divisions:
|
||||||
for i in range(1, divisions): # since divisions is the floor of total_locations / 25
|
for i in range(1, divisions + 1): # since divisions is the floor of total_locations / 25
|
||||||
event_loc = multiworld.get_location(f"Pickup{i * event_location_step}", player)
|
if i * event_location_step != total_locations:
|
||||||
set_rule(event_loc,
|
event_loc = multiworld.get_location(f"Pickup{i * event_location_step}", player)
|
||||||
lambda state, i=i: state.can_reach(f"ItemPickup{i * event_location_step - 1}", "Location", player))
|
set_rule(event_loc,
|
||||||
for n in range(i * event_location_step, (i + 1) * event_location_step): # we want to create a rule for each of the 25 locations per division
|
lambda state, i=i: state.can_reach(f"ItemPickup{i * event_location_step - 1}", "Location", player))
|
||||||
|
for n in range(i * event_location_step, (i + 1) * event_location_step + 1): # we want to create a rule for each of the 25 locations per division
|
||||||
|
if n > total_locations:
|
||||||
|
break
|
||||||
if n == i * event_location_step:
|
if n == i * event_location_step:
|
||||||
set_rule(multiworld.get_location(f"ItemPickup{n}", player),
|
set_rule(multiworld.get_location(f"ItemPickup{n}", player),
|
||||||
lambda state, event_item=event_loc.item.name: state.has(event_item, player))
|
lambda state, event_item=event_loc.item.name: state.has(event_item, player))
|
||||||
else:
|
else:
|
||||||
set_rule(multiworld.get_location(f"ItemPickup{n}", player),
|
set_rule(multiworld.get_location(f"ItemPickup{n}", player),
|
||||||
lambda state, n=n: state.can_reach(f"ItemPickup{n - 1}", "Location", player))
|
lambda state, n=n: state.can_reach(f"ItemPickup{n - 1}", "Location", player))
|
||||||
for i in range(divisions * event_location_step, total_locations+1):
|
|
||||||
set_rule(multiworld.get_location(f"ItemPickup{i}", player),
|
|
||||||
lambda state, i=i: state.can_reach(f"ItemPickup{i - 1}", "Location", player))
|
|
||||||
set_rule(multiworld.get_location("Victory", player),
|
set_rule(multiworld.get_location("Victory", player),
|
||||||
lambda state: state.can_reach(f"ItemPickup{total_locations}", "Location", player))
|
lambda state: state.can_reach(f"ItemPickup{total_locations}", "Location", player))
|
||||||
if total_revivals or multiworld.start_with_revive[player].value:
|
if total_revivals or multiworld.start_with_revive[player].value:
|
||||||
|
|
Loading…
Reference in New Issue