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:
		 Natalie Weizenbaum
					Natalie Weizenbaum
				
			
				
					committed by
					
						 GitHub
						GitHub
					
				
			
			
				
	
			
			
			 GitHub
						GitHub
					
				
			
						parent
						
							08dc7e522e
						
					
				
				
					commit
					b1be597451
				
			| @@ -238,15 +238,6 @@ class DS3ItemData: | ||||
|             ds3_code = cast(int, self.ds3_code) + level, | ||||
|             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): | ||||
|   | ||||
| @@ -1504,16 +1504,19 @@ class DarkSouls3World(World): | ||||
|         # 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 | ||||
|         # practice `item_dictionary.values()` doesn't include upgraded or infused weapons. | ||||
|         all_items = { | ||||
|             cast(DarkSouls3Item, location.item).data | ||||
|         items_by_name = { | ||||
|             location.item.name: cast(DarkSouls3Item, location.item).data | ||||
|             for location in self.multiworld.get_filled_locations() | ||||
|             # 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 | ||||
|         }.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] = {} | ||||
|         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.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 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user