Re-added pipe network connection map
This commit is contained in:
parent
95ce03ee48
commit
06dd77d2cc
3 changed files with 72 additions and 11 deletions
|
@ -28,7 +28,6 @@ public class FluidNetwork extends Network<IFluidNetwork, IFluidPart, IFluidHandl
|
||||||
@Override
|
@Override
|
||||||
public void reconstruct()
|
public void reconstruct()
|
||||||
{
|
{
|
||||||
System.out.println("Rebuilding network");
|
|
||||||
if (this.reloadTanks)
|
if (this.reloadTanks)
|
||||||
{
|
{
|
||||||
this.reloadTanks();
|
this.reloadTanks();
|
||||||
|
@ -81,7 +80,6 @@ public class FluidNetwork extends Network<IFluidNetwork, IFluidPart, IFluidHandl
|
||||||
@Override
|
@Override
|
||||||
public int fill(IFluidPart source, ForgeDirection from, FluidStack resource, boolean doFill)
|
public int fill(IFluidPart source, ForgeDirection from, FluidStack resource, boolean doFill)
|
||||||
{
|
{
|
||||||
System.out.println("Filling network tank");
|
|
||||||
int prev = this.getTank().getFluidAmount();
|
int prev = this.getTank().getFluidAmount();
|
||||||
int fill = this.getTank().fill(resource, doFill);
|
int fill = this.getTank().fill(resource, doFill);
|
||||||
if (prev != this.getTank().getFluid().amount)
|
if (prev != this.getTank().getFluid().amount)
|
||||||
|
@ -94,7 +92,6 @@ public class FluidNetwork extends Network<IFluidNetwork, IFluidPart, IFluidHandl
|
||||||
@Override
|
@Override
|
||||||
public FluidStack drain(IFluidPart source, ForgeDirection from, FluidStack resource, boolean doDrain)
|
public FluidStack drain(IFluidPart source, ForgeDirection from, FluidStack resource, boolean doDrain)
|
||||||
{
|
{
|
||||||
System.out.println("Draining network tank");
|
|
||||||
if (resource != null && resource.isFluidEqual(this.getTank().getFluid()))
|
if (resource != null && resource.isFluidEqual(this.getTank().getFluid()))
|
||||||
{
|
{
|
||||||
FluidStack before = this.getTank().getFluid();
|
FluidStack before = this.getTank().getFluid();
|
||||||
|
@ -149,7 +146,6 @@ public class FluidNetwork extends Network<IFluidNetwork, IFluidPart, IFluidHandl
|
||||||
public void reloadTanks()
|
public void reloadTanks()
|
||||||
{
|
{
|
||||||
this.reloadTanks = false;
|
this.reloadTanks = false;
|
||||||
System.out.println("Reloading fluids");
|
|
||||||
FluidStack stack = this.getTank().getFluid();
|
FluidStack stack = this.getTank().getFluid();
|
||||||
|
|
||||||
if (stack != null)
|
if (stack != null)
|
||||||
|
|
|
@ -1,10 +1,79 @@
|
||||||
package resonantinduction.mechanical.fluid.pipe;
|
package resonantinduction.mechanical.fluid.pipe;
|
||||||
|
|
||||||
|
import java.util.EnumSet;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import net.minecraftforge.common.ForgeDirection;
|
||||||
|
import net.minecraftforge.fluids.FluidStack;
|
||||||
|
import net.minecraftforge.fluids.IFluidHandler;
|
||||||
|
import resonantinduction.api.fluid.IFluidPart;
|
||||||
import resonantinduction.mechanical.fluid.network.FluidNetwork;
|
import resonantinduction.mechanical.fluid.network.FluidNetwork;
|
||||||
|
|
||||||
/** @author DarkGuardsman */
|
/** @author DarkGuardsman */
|
||||||
public class PipeNetwork extends FluidNetwork
|
public class PipeNetwork extends FluidNetwork
|
||||||
{
|
{
|
||||||
//TODO implements pressure for future hydraulic machines
|
public HashMap<IFluidHandler, EnumSet<ForgeDirection>> connectionMap = new HashMap<IFluidHandler, EnumSet<ForgeDirection>>();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void update()
|
||||||
|
{
|
||||||
|
//Slight delay to allow visual effect to take place before draining the pipe tanks
|
||||||
|
if (this.ticks % 3 == 0)
|
||||||
|
{
|
||||||
|
//TODO find a home for all fluid stored
|
||||||
|
//TODO limit input per machine by pipe connected
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean canUpdate()
|
||||||
|
{
|
||||||
|
return super.canUpdate() || this.getTank().getFluid() != null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean continueUpdate()
|
||||||
|
{
|
||||||
|
return super.canUpdate() || this.getTank().getFluid() != null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void reconstruct()
|
||||||
|
{
|
||||||
|
this.connectionMap.clear();
|
||||||
|
super.reconstruct();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void buildPart(IFluidPart part)
|
||||||
|
{
|
||||||
|
super.buildPart(part);
|
||||||
|
for (int i = 0; i < 6; i++)
|
||||||
|
{
|
||||||
|
if (part.getConnections()[i] instanceof IFluidHandler)
|
||||||
|
{
|
||||||
|
EnumSet<ForgeDirection> set = this.connectionMap.get(part.getConnections()[i]);
|
||||||
|
if (set == null)
|
||||||
|
{
|
||||||
|
set = EnumSet.noneOf(ForgeDirection.class);
|
||||||
|
}
|
||||||
|
set.add(ForgeDirection.getOrientation(i).getOpposite());
|
||||||
|
this.connectionMap.put((IFluidHandler) part.getConnections()[i], set);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FluidStack drain(IFluidPart source, ForgeDirection from, FluidStack resource, boolean doDrain)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FluidStack drain(IFluidPart source, ForgeDirection from, int resource, boolean doDrain)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,9 @@
|
||||||
package resonantinduction.mechanical.network;
|
package resonantinduction.mechanical.network;
|
||||||
|
|
||||||
import java.util.EnumSet;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import net.minecraftforge.common.ForgeDirection;
|
import net.minecraftforge.common.ForgeDirection;
|
||||||
import universalelectricity.api.CompatibilityModule;
|
|
||||||
import universalelectricity.api.energy.IConductor;
|
|
||||||
import universalelectricity.api.net.IConnector;
|
import universalelectricity.api.net.IConnector;
|
||||||
import universalelectricity.core.net.ConnectionPathfinder;
|
import universalelectricity.core.net.ConnectionPathfinder;
|
||||||
import universalelectricity.core.net.Network;
|
import universalelectricity.core.net.Network;
|
||||||
|
|
Loading…
Reference in a new issue