Working on item networks for AL

This commit is contained in:
Robert 2013-11-09 11:27:56 -05:00
parent 06c4b331b6
commit 4d17561a37
8 changed files with 230 additions and 86 deletions

View file

@ -1,57 +0,0 @@
package basiccomponents.api;
import java.util.HashSet;
import java.util.Set;
/**
* This should be the only class you include in your mod. If your mod is a coremod, feel free to
* download Basic Components Core directly during run-time.
*
* @author Calclavia
*/
public class BasicRegistry
{
public static final Set<String> requests = new HashSet<String>();
/**
* @param request - Name of the item/block to register. Use the EXACT FIELD NAME of the
* BasicComponents.java field.
*/
public static void register(String request)
{
requests.add(request);
}
/**
* Requests all items in Basic Components.
*/
public static void requestAll()
{
register("ingotCopper");
register("ingotTin");
register("oreCopper");
register("oreTin");
register("ingotSteel");
register("dustSteel");
register("plateSteel");
register("ingotBronze");
register("dustBronze");
register("plateBronze");
register("plateCopper");
register("plateTin");
register("plateIron");
register("plateGold");
register("circuitBasic");
register("circuitAdvanced");
register("circuitElite");
register("motor");
register("wrench");
}
}

View file

@ -0,0 +1,22 @@
package dark.api.parts;
import universalelectricity.core.vector.Vector3;
import net.minecraft.entity.Entity;
import net.minecraftforge.common.ForgeDirection;
public interface IMotionPath
{
/** Gets the motion applied to the entity while its on the tile **/
public Vector3 getMotion(Entity entity);
/** Can the path controller move the entity over this tile. Make sure to check the position of
* the tile as the controller doesn't know the range of control of the tile. Though it does
* limit itself to blocks around the entity. So if your tile only effects entities above it
* within its bound then make sure the tile is inside those bounds
*
* @param entity - entity in question
* @param from - direction the entity came from
* @return true if it can, false if something is wrong like no power, or solid side */
public boolean canMoveEntity(Entity entity);
}

View file

@ -28,6 +28,9 @@ public interface ITileNetwork
/** Called when this network is just created */ /** Called when this network is just created */
public void onCreated(); public void onCreated();
/** How many ticks should base between updates, return 0 or bellow for no ticks */
public int getUpdateRate();
/** Called every so many ticks so the network has a chance to update */ /** Called every so many ticks so the network has a chance to update */
public void updateTick(); public void updateTick();

View file

@ -19,9 +19,11 @@ import cpw.mods.fml.common.Mod.EventHandler;
import cpw.mods.fml.common.event.FMLInitializationEvent; import cpw.mods.fml.common.event.FMLInitializationEvent;
import cpw.mods.fml.common.event.FMLPostInitializationEvent; import cpw.mods.fml.common.event.FMLPostInitializationEvent;
import cpw.mods.fml.common.event.FMLPreInitializationEvent; import cpw.mods.fml.common.event.FMLPreInitializationEvent;
import cpw.mods.fml.common.registry.TickRegistry;
import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.Side;
import dark.core.common.ExternalModHandler; import dark.core.common.ExternalModHandler;
import dark.core.prefab.helpers.FluidHelper; import dark.core.prefab.helpers.FluidHelper;
import dark.core.prefab.tilenetwork.NetworkUpdateHandler;
import dark.core.registration.ModObjectRegistry; import dark.core.registration.ModObjectRegistry;
import dark.core.save.SaveManager; import dark.core.save.SaveManager;
@ -48,6 +50,8 @@ public abstract class ModPrefab
private static Triple<Integer, Integer, Integer> date; private static Triple<Integer, Integer, Integer> date;
private static boolean preInit, init, postInit;
public abstract String getDomain(); public abstract String getDomain();
/** Gets the next unused ID in the block list. Does not prevent config file issues after the file /** Gets the next unused ID in the block list. Does not prevent config file issues after the file
@ -92,26 +96,41 @@ public abstract class ModPrefab
public void preInit(FMLPreInitializationEvent event) public void preInit(FMLPreInitializationEvent event)
{ {
this.loadModMeta(); this.loadModMeta();
Modstats.instance().getReporter().registerMod(this); Modstats.instance().getReporter().registerMod(this);
MinecraftForge.EVENT_BUS.register(this); MinecraftForge.EVENT_BUS.register(this);
if (!preInit)
{
MinecraftForge.EVENT_BUS.register(new FluidHelper()); MinecraftForge.EVENT_BUS.register(new FluidHelper());
MinecraftForge.EVENT_BUS.register(SaveManager.instance()); MinecraftForge.EVENT_BUS.register(SaveManager.instance());
TickRegistry.registerTickHandler(NetworkUpdateHandler.instance(), Side.SERVER);
UniversalElectricity.initiate(); UniversalElectricity.initiate();
Compatibility.initiate(); Compatibility.initiate();
preInit = true;
}
} }
@EventHandler @EventHandler
public void init(FMLInitializationEvent event) public void init(FMLInitializationEvent event)
{
if (!init)
{ {
ExternalModHandler.init(); ExternalModHandler.init();
ModObjectRegistry.masterBlockConfig.load(); ModObjectRegistry.masterBlockConfig.load();
init = true;
}
this.registerObjects(); this.registerObjects();
ModObjectRegistry.masterBlockConfig.save();
} }
@EventHandler @EventHandler
public void postInit(FMLPostInitializationEvent event) public void postInit(FMLPostInitializationEvent event)
{ {
if (!postInit)
{
ModObjectRegistry.masterBlockConfig.save();
postInit = true;
}
this.loadRecipes(); this.loadRecipes();
} }

View file

@ -0,0 +1,119 @@
package dark.core.prefab.tilenetwork;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import net.minecraft.entity.Entity;
import net.minecraft.tileentity.TileEntity;
import net.minecraftforge.common.ForgeDirection;
import universalelectricity.core.vector.Vector3;
import com.builtbroken.common.Pair;
import dark.api.parts.IMotionPath;
import dark.api.parts.INetworkPart;
/** Class that acts like the redpower pipes system. Each item is marked with a destination. Intended
* use it to improve the assembly line network
*
* @author DarkGuardsman */
public class NetworkItemSupply extends NetworkTileEntities
{
List<Pair<Entity, Vector3>> trackingList = new ArrayList<Pair<Entity, Vector3>>();
List<Entity> ignoreList = new ArrayList<Entity>();
/** Same as valid directions from forge direction enum but Unknown was added so that is gets check and checked first */
public static final ForgeDirection[] VALID_DIRECTIONS = {ForgeDirection.UNKNOWN, ForgeDirection.DOWN, ForgeDirection.UP, ForgeDirection.NORTH, ForgeDirection.SOUTH, ForgeDirection.WEST, ForgeDirection.EAST};
public NetworkItemSupply(INetworkPart... parts)
{
super(parts);
}
@Override
public void updateTick()
{
Iterator<Pair<Entity, Vector3>> it = trackingList.iterator();
while (it.hasNext())
{
Pair<Entity, Vector3> entry = it.next();
if (entry.left() == null || !this.isOnPath(entry.left()))
{
it.remove();
}
else
{
if (entry.right() == null)
{
entry.setRight(new Vector3(entry.left()));
}
else
{
entry.left().setPosition(entry.right().x, entry.right().y, entry.right().z);
}
}
}
}
@Override
public int getUpdateRate()
{
return 1;
}
/** Remove an entity from the tracking list */
public void removeEntity(Entity entity)
{
this.trackingList.remove(entity);
}
/** Ignores an entity so that is can be controlled by something else for a while. Eg armbots, and
* drones */
public void ignoreEntity(Entity entity)
{
if (!this.ignoreList.contains(entity))
{
this.ignoreList.add(entity);
}
}
/** Add and entity to the tracking list */
public void addEntity(Entity entity)
{
if (!this.trackingList.contains(entity))
{
this.trackingList.add(new Pair<Entity, Vector3>(entity, new Vector3(entity)));
}
}
public boolean isTrackingEntity(Entity entity)
{
return this.trackingList.contains(entity);
}
public boolean isOnPath(Entity entity)
{
if (entity != null)
{
Vector3 ent = new Vector3(entity);
//Check all directions including the current position of the entity
for (ForgeDirection direction : this.VALID_DIRECTIONS)
{
TileEntity a = ent.clone().modifyPositionFromSide(direction).getTileEntity(entity.worldObj);
if (a instanceof IMotionPath && ((IMotionPath) a).canMoveEntity(entity) && this.networkMembers.contains(a))
{
return true;
}
}
}
return false;
}
@Override
public boolean isValidMember(INetworkPart part)
{
return super.isValidMember(part) && part instanceof IMotionPath;
}
}

View file

@ -0,0 +1,29 @@
package dark.core.prefab.tilenetwork;
import java.util.HashMap;
import java.util.List;
import net.minecraft.tileentity.TileEntity;
import net.minecraftforge.common.ForgeDirection;
import dark.api.parts.INetworkPart;
/** Network that supplies resources to tiles that demand a set resource
*
* @param C - Storage class used to handle what the network transports
* @param I - Base acceptor class
* @author DarkGuardsman */
public class NetworkResourceSupply<C, I> extends NetworkTileEntities
{
protected C storage;
protected HashMap<I, List<ForgeDirection>> acceptors = new HashMap();
public NetworkResourceSupply(INetworkPart... parts)
{
super(parts);
}
public boolean isValidAcceptor(TileEntity entity)
{
return entity != null && !entity.isInvalid();
}
}

View file

@ -19,11 +19,12 @@ public class NetworkTileEntities implements ITileNetwork
public NetworkTileEntities() public NetworkTileEntities()
{ {
NetworkUpdateHandler.instance().registerNetwork(this);
} }
public NetworkTileEntities(INetworkPart... parts) public NetworkTileEntities(INetworkPart... parts)
{ {
this();
if (parts != null) if (parts != null)
{ {
for (INetworkPart part : parts) for (INetworkPart part : parts)
@ -56,6 +57,12 @@ public class NetworkTileEntities implements ITileNetwork
this.cleanUpMembers(); this.cleanUpMembers();
} }
@Override
public int getUpdateRate()
{
return -1;
}
@Override @Override
public void updateTick() public void updateTick()
{ {
@ -170,7 +177,7 @@ public class NetworkTileEntities implements ITileNetwork
/** Merges the two networks together */ /** Merges the two networks together */
protected void mergeDo(ITileNetwork network) protected void mergeDo(ITileNetwork network)
{ {
ITileNetwork newNetwork = NetworkHandler.createNewNetwork(NetworkHandler.getID(this.getClass())); ITileNetwork newNetwork = NetworkUpdateHandler.createNewNetwork(NetworkUpdateHandler.getID(this.getClass()));
newNetwork.getMembers().addAll(this.getMembers()); newNetwork.getMembers().addAll(this.getMembers());
newNetwork.getMembers().addAll(network.getMembers()); newNetwork.getMembers().addAll(network.getMembers());
newNetwork.onCreated(); newNetwork.onCreated();
@ -200,7 +207,7 @@ public class NetworkTileEntities implements ITileNetwork
{ {
this.save(); this.save();
/* NO LONGER CONNECTED ELSE WHERE SO SPLIT AND REFRESH */ /* NO LONGER CONNECTED ELSE WHERE SO SPLIT AND REFRESH */
ITileNetwork newNetwork = NetworkHandler.createNewNetwork(NetworkHandler.getID(this.getClass())); ITileNetwork newNetwork = NetworkUpdateHandler.createNewNetwork(NetworkUpdateHandler.getID(this.getClass()));
if (newNetwork != null) if (newNetwork != null)
{ {
for (Vector3 node : finder.closedSet) for (Vector3 node : finder.closedSet)

View file

@ -7,42 +7,49 @@ import java.util.Iterator;
import java.util.Set; import java.util.Set;
import cpw.mods.fml.common.IScheduledTickHandler; import cpw.mods.fml.common.IScheduledTickHandler;
import cpw.mods.fml.common.ITickHandler;
import cpw.mods.fml.common.TickType; import cpw.mods.fml.common.TickType;
import dark.api.parts.ITileNetwork; import dark.api.parts.ITileNetwork;
/** Manages all the tile networks making sure they get world save events, and updates every so often /** Manages all the tile networks making sure they get world save events, and updates every so often
* *
* @author DarkGuardsman */ * @author DarkGuardsman */
public class NetworkHandler implements IScheduledTickHandler public class NetworkUpdateHandler implements ITickHandler
{ {
private static HashMap<String, Class<?>> nameToClassMap = new HashMap<String, Class<?>>(); private static HashMap<String, Class<?>> nameToClassMap = new HashMap<String, Class<?>>();
private static HashMap<Class<?>, String> classToNameMap = new HashMap<Class<?>, String>(); private static HashMap<Class<?>, String> classToNameMap = new HashMap<Class<?>, String>();
private byte count = 0; private int count = 0;
private static int refreshTicks = 6000;
private Set<ITileNetwork> networks = new HashSet(); private Set<ITileNetwork> activeNetworks = new HashSet();
private Set<ITileNetwork> allNetworks = new HashSet();
private static NetworkHandler instance; private static NetworkUpdateHandler instance;
static static
{ {
registerNetworkClass("base", NetworkTileEntities.class); registerNetworkClass("base", NetworkTileEntities.class);
} }
public static NetworkHandler instance() public static NetworkUpdateHandler instance()
{ {
if (instance == null) if (instance == null)
{ {
instance = new NetworkHandler(); instance = new NetworkUpdateHandler();
} }
return instance; return instance;
} }
public void registerNetwork(ITileNetwork network) public void registerNetwork(ITileNetwork network)
{ {
if (!networks.contains(network)) if (network != null && !activeNetworks.contains(network))
{ {
this.networks.add(network); this.allNetworks.add(network);
if (network.getUpdateRate() > 0)
{
this.activeNetworks.add(network);
}
} }
} }
@ -95,10 +102,10 @@ public class NetworkHandler implements IScheduledTickHandler
@Override @Override
public void tickStart(EnumSet<TickType> type, Object... tickData) public void tickStart(EnumSet<TickType> type, Object... tickData)
{ {
if (count + 1 >= Byte.MAX_VALUE) if (count + 1 >= this.refreshTicks)
{ {
count = 0; count = 0;
for (ITileNetwork network : networks) for (ITileNetwork network : allNetworks)
{ {
if (!network.isInvalid()) if (!network.isInvalid())
{ {
@ -109,7 +116,7 @@ public class NetworkHandler implements IScheduledTickHandler
else else
{ {
count++; count++;
for (ITileNetwork network : networks) for (ITileNetwork network : activeNetworks)
{ {
if (!network.isInvalid()) if (!network.isInvalid())
{ {
@ -123,7 +130,7 @@ public class NetworkHandler implements IScheduledTickHandler
@Override @Override
public void tickEnd(EnumSet<TickType> type, Object... tickData) public void tickEnd(EnumSet<TickType> type, Object... tickData)
{ {
Iterator<ITileNetwork> it = networks.iterator(); Iterator<ITileNetwork> it = activeNetworks.iterator();
while (it.hasNext()) while (it.hasNext())
{ {
ITileNetwork network = it.next(); ITileNetwork network = it.next();
@ -131,6 +138,7 @@ public class NetworkHandler implements IScheduledTickHandler
{ {
network.invalidate(); network.invalidate();
it.remove(); it.remove();
allNetworks.remove(network);
} }
} }
@ -147,10 +155,4 @@ public class NetworkHandler implements IScheduledTickHandler
{ {
return "[CoreMachine]TileNetworkHandler"; return "[CoreMachine]TileNetworkHandler";
} }
@Override
public int nextTickSpacing()
{
return 20;
}
} }