Ensure slave maps are cleaned up when handling registry overrides (#5250)

This commit is contained in:
Ben Staddon 2019-01-04 01:36:32 +00:00 committed by tterrag
parent cb3ff19801
commit 8b5a5ecd74

View file

@ -273,6 +273,15 @@ public class GameData
this.objectList.clear(); this.objectList.clear();
this.nextId = 0; this.nextId = 0;
} }
void remove(I key)
{
Integer prev = this.identityMap.remove(key);
if (prev != null)
{
this.objectList.set(prev, null);
}
}
} }
private static class BlockCallbacks implements IForgeRegistry.AddCallback<Block>, IForgeRegistry.ClearCallback<Block>, IForgeRegistry.BakeCallback<Block>, IForgeRegistry.CreateCallback<Block>, IForgeRegistry.DummyFactory<Block> private static class BlockCallbacks implements IForgeRegistry.AddCallback<Block>, IForgeRegistry.ClearCallback<Block>, IForgeRegistry.BakeCallback<Block>, IForgeRegistry.CreateCallback<Block>, IForgeRegistry.DummyFactory<Block>
@ -316,6 +325,14 @@ public class GameData
} }
/* /*
if (oldBlock != null)
{
for (IBlockState state : oldBlock.getBlockState().getValidStates())
{
blockstateMap.remove(state);
}
}
if ("minecraft:tripwire".equals(block.getRegistryName().toString())) //Tripwire is crap so we have to special case whee! if ("minecraft:tripwire".equals(block.getRegistryName().toString())) //Tripwire is crap so we have to special case whee!
{ {
for (int meta = 0; meta < 15; meta++) for (int meta = 0; meta < 15; meta++)
@ -424,6 +441,12 @@ public class GameData
@Override @Override
public void onAdd(IForgeRegistryInternal<Item> owner, RegistryManager stage, int id, Item item, @Nullable Item oldItem) public void onAdd(IForgeRegistryInternal<Item> owner, RegistryManager stage, int id, Item item, @Nullable Item oldItem)
{ {
if (oldItem instanceof ItemBlock)
{
@SuppressWarnings("unchecked")
BiMap<Block, Item> blockToItem = owner.getSlaveMap(BLOCK_TO_ITEM, BiMap.class);
blockToItem.remove(((ItemBlock)oldItem).getBlock());
}
if (item instanceof ItemBlock) if (item instanceof ItemBlock)
{ {
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
@ -513,6 +536,7 @@ public class GameData
EntityList.ENTITY_EGGS.put(entry.getRegistryName(), entry.getEgg()); EntityList.ENTITY_EGGS.put(entry.getRegistryName(), entry.getEgg());
} }
} }
}
*/ */
private static <T extends IForgeRegistryEntry<T>> void loadRegistry(final ResourceLocation registryName, final RegistryManager from, final RegistryManager to, final Class<T> regType, boolean freeze) private static <T extends IForgeRegistryEntry<T>> void loadRegistry(final ResourceLocation registryName, final RegistryManager from, final RegistryManager to, final Class<T> regType, boolean freeze)