Mekanism-tilera-Edition/common/mekanism/api/transmitters/TransmitterNetworkRegistry.java

163 lines
3.8 KiB
Java
Raw Normal View History

package mekanism.api.transmitters;
import java.util.EnumSet;
2013-11-03 16:54:33 -05:00
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
2013-11-03 16:54:33 -05:00
import java.util.Map;
import java.util.Set;
2013-11-03 16:54:33 -05:00
2013-08-18 16:51:47 -04:00
import net.minecraft.tileentity.TileEntity;
import net.minecraft.world.chunk.Chunk;
import net.minecraft.world.chunk.IChunkProvider;
2013-08-18 16:51:47 -04:00
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.event.ForgeSubscribe;
import net.minecraftforge.event.world.ChunkEvent;
import cpw.mods.fml.common.ITickHandler;
import cpw.mods.fml.common.TickType;
import cpw.mods.fml.common.registry.TickRegistry;
import cpw.mods.fml.relauncher.Side;
2013-08-04 01:18:43 +01:00
public class TransmitterNetworkRegistry implements ITickHandler
{
2013-08-04 01:18:43 +01:00
private static TransmitterNetworkRegistry INSTANCE = new TransmitterNetworkRegistry();
2013-08-18 16:51:47 -04:00
private static boolean loaderRegistered = false;
2013-08-04 01:18:43 +01:00
private HashSet<ITransmitterNetwork> networks = new HashSet<ITransmitterNetwork>();
2013-08-04 01:18:43 +01:00
public TransmitterNetworkRegistry()
{
TickRegistry.registerTickHandler(this, Side.SERVER);
}
2013-08-18 16:51:47 -04:00
public static void initiate()
{
if(!loaderRegistered)
{
loaderRegistered = true;
MinecraftForge.EVENT_BUS.register(new NetworkLoader());
2013-08-18 16:51:47 -04:00
}
}
2013-08-04 01:18:43 +01:00
public static TransmitterNetworkRegistry getInstance()
{
return INSTANCE;
}
2013-08-04 01:18:43 +01:00
public void registerNetwork(ITransmitterNetwork network)
{
networks.add(network);
}
2013-08-04 01:18:43 +01:00
public void removeNetwork(ITransmitterNetwork network)
{
if(networks.contains(network))
{
networks.remove(network);
}
}
2013-07-31 16:44:53 -04:00
public void pruneEmptyNetworks()
{
HashSet<ITransmitterNetwork> copySet = new HashSet<ITransmitterNetwork>(networks);
for(ITransmitterNetwork e : copySet)
2013-07-28 03:32:41 +01:00
{
2013-08-04 01:18:43 +01:00
if(e.getSize() == 0)
2013-07-28 03:32:41 +01:00
{
removeNetwork(e);
}
}
}
@Override
public void tickStart(EnumSet<TickType> type, Object... tickData) {}
@Override
public void tickEnd(EnumSet<TickType> type, Object... tickData)
{
Set<ITransmitterNetwork> iterNetworks = (Set<ITransmitterNetwork>)networks.clone();
2013-08-04 01:18:43 +01:00
for(ITransmitterNetwork net : iterNetworks)
{
2013-07-28 03:32:41 +01:00
if(networks.contains(net))
{
net.tick();
}
}
}
@Override
public EnumSet<TickType> ticks()
{
return EnumSet.of(TickType.SERVER);
}
@Override
public String getLabel()
{
return "MekanismNetworks";
}
@Override
public String toString()
{
2013-08-04 01:18:43 +01:00
return "Network Registry:\n" + networks;
}
2013-08-18 16:51:47 -04:00
public static class NetworkLoader
{
@ForgeSubscribe
public void onChunkLoad(ChunkEvent.Load event)
{
if(event.getChunk() != null)
{
int x = event.getChunk().xPosition;
int z = event.getChunk().zPosition;
IChunkProvider cProvider = event.getChunk().worldObj.getChunkProvider();
Chunk[] neighbors = new Chunk[5];
neighbors[0] = event.getChunk();
if(cProvider.chunkExists(x + 1, z)) neighbors[1] = cProvider.provideChunk(x + 1, z);
if(cProvider.chunkExists(x - 1, z)) neighbors[2] = cProvider.provideChunk(x - 1, z);
if(cProvider.chunkExists(x, z + 1)) neighbors[3] = cProvider.provideChunk(x, z + 1);
if(cProvider.chunkExists(x, z - 1)) neighbors[4] = cProvider.provideChunk(x, z - 1);
for(Chunk c : neighbors)
{
refreshChunk(c);
}
}
}
public synchronized void refreshChunk(Chunk c)
{
try {
if(c != null)
{
2013-11-03 16:54:33 -05:00
Map copy = (Map)((HashMap)c.chunkTileEntityMap).clone();
for(Object obj : copy.values())
{
if(obj instanceof TileEntity)
{
TileEntity tileEntity = (TileEntity)obj;
if(tileEntity instanceof ITransmitter)
{
((ITransmitter)tileEntity).refreshTransmitterNetwork();
((ITransmitter)tileEntity).chunkLoad();
}
}
}
}
} catch(Exception e) {
e.printStackTrace();
}
2013-08-18 16:51:47 -04:00
}
}
}