mirror of
https://github.com/MarioSpore/Grinch-AP.git
synced 2025-10-21 20:21:32 -06:00
DS3: Explicitly track item equality by name when sending IDs (#3853)
We had been keeping a set of items and defining item equality, but item equality really only makes sense if you consider distinct IDs to be distinct items. But that means the set ends up having multiple copies of the same item, causing a bug where some items had the wrong upgrade level in the game. This also removes the equality definition, which was only used by this one set.
This commit is contained in:

committed by
GitHub

parent
08dc7e522e
commit
b1be597451
@@ -238,15 +238,6 @@ class DS3ItemData:
|
|||||||
ds3_code = cast(int, self.ds3_code) + level,
|
ds3_code = cast(int, self.ds3_code) + level,
|
||||||
filler = False,
|
filler = False,
|
||||||
)
|
)
|
||||||
|
|
||||||
def __hash__(self) -> int:
|
|
||||||
return (self.name, self.ds3_code).__hash__()
|
|
||||||
|
|
||||||
def __eq__(self, other: Any) -> bool:
|
|
||||||
if isinstance(other, self.__class__):
|
|
||||||
return self.name == other.name and self.ds3_code == other.ds3_code
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
|
|
||||||
class DarkSouls3Item(Item):
|
class DarkSouls3Item(Item):
|
||||||
|
@@ -1504,16 +1504,19 @@ class DarkSouls3World(World):
|
|||||||
# We include all the items the game knows about so that users can manually request items
|
# We include all the items the game knows about so that users can manually request items
|
||||||
# that aren't randomized, and then we _also_ include all the items that are placed in
|
# that aren't randomized, and then we _also_ include all the items that are placed in
|
||||||
# practice `item_dictionary.values()` doesn't include upgraded or infused weapons.
|
# practice `item_dictionary.values()` doesn't include upgraded or infused weapons.
|
||||||
all_items = {
|
items_by_name = {
|
||||||
cast(DarkSouls3Item, location.item).data
|
location.item.name: cast(DarkSouls3Item, location.item).data
|
||||||
for location in self.multiworld.get_filled_locations()
|
for location in self.multiworld.get_filled_locations()
|
||||||
# item.code None is used for events, which we want to skip
|
# item.code None is used for events, which we want to skip
|
||||||
if location.item.code is not None and location.item.player == self.player
|
if location.item.code is not None and location.item.player == self.player
|
||||||
}.union(item_dictionary.values())
|
}
|
||||||
|
for item in item_dictionary.values():
|
||||||
|
if item.name not in items_by_name:
|
||||||
|
items_by_name[item.name] = item
|
||||||
|
|
||||||
ap_ids_to_ds3_ids: Dict[str, int] = {}
|
ap_ids_to_ds3_ids: Dict[str, int] = {}
|
||||||
item_counts: Dict[str, int] = {}
|
item_counts: Dict[str, int] = {}
|
||||||
for item in all_items:
|
for item in items_by_name.values():
|
||||||
if item.ap_code is None: continue
|
if item.ap_code is None: continue
|
||||||
if item.ds3_code: ap_ids_to_ds3_ids[str(item.ap_code)] = item.ds3_code
|
if item.ds3_code: ap_ids_to_ds3_ids[str(item.ap_code)] = item.ds3_code
|
||||||
if item.count != 1: item_counts[str(item.ap_code)] = item.count
|
if item.count != 1: item_counts[str(item.ap_code)] = item.count
|
||||||
|
Reference in New Issue
Block a user