2013-06-26 23:49:47 +02:00
|
|
|
package mekanism.common;
|
|
|
|
|
2013-08-25 03:22:45 +02:00
|
|
|
import java.util.ArrayList;
|
2013-06-26 23:49:47 +02:00
|
|
|
import java.util.Arrays;
|
2013-08-19 03:32:47 +02:00
|
|
|
import java.util.Collection;
|
2013-06-26 23:49:47 +02:00
|
|
|
import java.util.Collections;
|
|
|
|
import java.util.HashSet;
|
|
|
|
import java.util.Iterator;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.Set;
|
|
|
|
|
2013-08-27 00:49:32 +02:00
|
|
|
import mekanism.api.transmitters.DynamicNetwork;
|
|
|
|
import mekanism.api.transmitters.ITransmitter;
|
|
|
|
import mekanism.api.transmitters.TransmissionType;
|
|
|
|
import mekanism.common.tileentity.TileEntityMechanicalPipe;
|
2013-12-17 18:53:33 +01:00
|
|
|
import mekanism.common.util.ListUtils;
|
2013-12-15 04:50:37 +01:00
|
|
|
import mekanism.common.util.PipeUtils;
|
2013-06-26 23:49:47 +02:00
|
|
|
import net.minecraft.tileentity.TileEntity;
|
|
|
|
import net.minecraftforge.common.ForgeDirection;
|
|
|
|
import net.minecraftforge.common.MinecraftForge;
|
|
|
|
import net.minecraftforge.event.Event;
|
2013-08-25 03:22:45 +02:00
|
|
|
import net.minecraftforge.fluids.Fluid;
|
|
|
|
import net.minecraftforge.fluids.FluidRegistry;
|
2013-07-20 18:10:14 +02:00
|
|
|
import net.minecraftforge.fluids.FluidStack;
|
|
|
|
import net.minecraftforge.fluids.IFluidHandler;
|
|
|
|
import cpw.mods.fml.common.FMLCommonHandler;
|
2013-06-26 23:49:47 +02:00
|
|
|
|
2013-12-06 13:57:26 +01:00
|
|
|
public class FluidNetwork extends DynamicNetwork<IFluidHandler, FluidNetwork>
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-12-14 06:36:52 +01:00
|
|
|
public static final int PIPE_FLUID = 1000;
|
|
|
|
|
2013-11-25 06:00:26 +01:00
|
|
|
public int transferDelay = 0;
|
|
|
|
|
2013-11-29 03:43:53 +01:00
|
|
|
public boolean didTransfer;
|
|
|
|
public boolean prevTransfer;
|
2013-11-25 06:00:26 +01:00
|
|
|
|
2013-11-29 03:43:53 +01:00
|
|
|
public float fluidScale;
|
2013-12-14 21:30:41 +01:00
|
|
|
public float prevScale;
|
|
|
|
|
2013-12-17 20:57:19 +01:00
|
|
|
/** Sent from server to client, actual stored buffer scale. Used by server as last-update scale. */
|
2013-12-14 21:30:41 +01:00
|
|
|
public float definedScale;
|
|
|
|
|
2013-11-25 06:00:26 +01:00
|
|
|
public Fluid refFluid = null;
|
|
|
|
|
2013-12-14 06:36:52 +01:00
|
|
|
public FluidStack fluidStored;
|
|
|
|
|
2013-12-06 13:57:26 +01:00
|
|
|
public FluidNetwork(ITransmitter<FluidNetwork>... varPipes)
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-08-17 19:32:05 +02:00
|
|
|
transmitters.addAll(Arrays.asList(varPipes));
|
2013-08-04 02:41:16 +02:00
|
|
|
register();
|
|
|
|
}
|
|
|
|
|
2013-12-06 13:57:26 +01:00
|
|
|
public FluidNetwork(Collection<ITransmitter<FluidNetwork>> collection)
|
2013-08-19 03:32:47 +02:00
|
|
|
{
|
|
|
|
transmitters.addAll(collection);
|
|
|
|
register();
|
|
|
|
}
|
|
|
|
|
2013-08-04 02:41:16 +02:00
|
|
|
public FluidNetwork(Set<FluidNetwork> networks)
|
|
|
|
{
|
|
|
|
for(FluidNetwork net : networks)
|
|
|
|
{
|
|
|
|
if(net != null)
|
|
|
|
{
|
2013-11-29 19:04:39 +01:00
|
|
|
if(net.refFluid != null && net.fluidScale > fluidScale)
|
|
|
|
{
|
|
|
|
refFluid = net.refFluid;
|
|
|
|
fluidScale = net.fluidScale;
|
|
|
|
}
|
|
|
|
|
2013-12-17 18:53:33 +01:00
|
|
|
if(net.fluidStored != null)
|
|
|
|
{
|
|
|
|
if(fluidStored == null)
|
|
|
|
{
|
|
|
|
fluidStored = net.fluidStored;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
fluidStored.amount += net.fluidStored.amount;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-17 19:32:05 +02:00
|
|
|
addAllTransmitters(net.transmitters);
|
2013-08-04 02:41:16 +02:00
|
|
|
net.deregister();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
refresh();
|
|
|
|
register();
|
2013-06-26 23:49:47 +02:00
|
|
|
}
|
|
|
|
|
2013-12-17 18:53:33 +01:00
|
|
|
@Override
|
|
|
|
public void onNetworksCreated(List<FluidNetwork> networks)
|
|
|
|
{
|
|
|
|
if(FMLCommonHandler.instance().getEffectiveSide().isServer())
|
|
|
|
{
|
|
|
|
if(fluidStored != null)
|
|
|
|
{
|
|
|
|
int[] caps = new int[networks.size()];
|
|
|
|
int cap = 0;
|
|
|
|
|
|
|
|
for(FluidNetwork network : networks)
|
|
|
|
{
|
|
|
|
caps[networks.indexOf(network)] = network.getCapacity();
|
|
|
|
cap += network.getCapacity();
|
|
|
|
}
|
|
|
|
|
|
|
|
fluidStored.amount = Math.min(cap, fluidStored.amount);
|
|
|
|
|
|
|
|
int[] values = ListUtils.calcPercentInt(ListUtils.percent(caps), fluidStored.amount);
|
|
|
|
|
|
|
|
for(FluidNetwork network : networks)
|
|
|
|
{
|
|
|
|
int index = networks.indexOf(network);
|
|
|
|
|
|
|
|
if(values[index] > 0)
|
|
|
|
{
|
|
|
|
network.fluidStored = new FluidStack(fluidStored.getFluid(), values[index]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-12-14 06:36:52 +01:00
|
|
|
public synchronized int getFluidNeeded()
|
|
|
|
{
|
|
|
|
return getCapacity()-(fluidStored != null ? fluidStored.amount : 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized int tickEmit(FluidStack fluidToSend, boolean doTransfer)
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-08-18 22:51:47 +02:00
|
|
|
List availableAcceptors = Arrays.asList(getAcceptors(fluidToSend).toArray());
|
2013-06-26 23:49:47 +02:00
|
|
|
|
|
|
|
Collections.shuffle(availableAcceptors);
|
|
|
|
|
2013-07-20 18:10:14 +02:00
|
|
|
int fluidSent = 0;
|
2013-06-26 23:49:47 +02:00
|
|
|
|
|
|
|
if(!availableAcceptors.isEmpty())
|
|
|
|
{
|
|
|
|
int divider = availableAcceptors.size();
|
2013-07-20 18:10:14 +02:00
|
|
|
int remaining = fluidToSend.amount % divider;
|
|
|
|
int sending = (fluidToSend.amount-remaining)/divider;
|
2013-06-26 23:49:47 +02:00
|
|
|
|
|
|
|
for(Object obj : availableAcceptors)
|
|
|
|
{
|
2013-12-14 06:36:52 +01:00
|
|
|
if(obj instanceof IFluidHandler)
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-07-20 18:10:14 +02:00
|
|
|
IFluidHandler acceptor = (IFluidHandler)obj;
|
2013-06-26 23:49:47 +02:00
|
|
|
int currentSending = sending;
|
|
|
|
|
|
|
|
if(remaining > 0)
|
|
|
|
{
|
|
|
|
currentSending++;
|
|
|
|
remaining--;
|
|
|
|
}
|
|
|
|
|
2013-12-13 03:35:17 +01:00
|
|
|
fluidSent += acceptor.fill(acceptorDirections.get(acceptor).getOpposite(), new FluidStack(fluidToSend.fluidID, currentSending), doTransfer);
|
2013-06-26 23:49:47 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-20 18:10:14 +02:00
|
|
|
if(doTransfer && fluidSent > 0 && FMLCommonHandler.instance().getEffectiveSide().isServer())
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-11-29 03:43:53 +01:00
|
|
|
didTransfer = true;
|
|
|
|
transferDelay = 2;
|
2013-06-26 23:49:47 +02:00
|
|
|
}
|
|
|
|
|
2013-07-20 18:10:14 +02:00
|
|
|
return fluidSent;
|
2013-06-26 23:49:47 +02:00
|
|
|
}
|
|
|
|
|
2013-12-14 06:36:52 +01:00
|
|
|
public synchronized int emit(FluidStack fluidToSend, boolean doTransfer)
|
|
|
|
{
|
|
|
|
if(fluidToSend == null || (fluidStored != null && fluidStored.getFluid() != fluidToSend.getFluid()))
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int toUse = Math.min(getFluidNeeded(), fluidToSend.amount);
|
|
|
|
|
|
|
|
if(doTransfer)
|
|
|
|
{
|
|
|
|
if(fluidStored == null)
|
|
|
|
{
|
|
|
|
fluidStored = fluidToSend.copy();
|
|
|
|
fluidStored.amount = toUse;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
fluidStored.amount += toUse;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return toUse;
|
|
|
|
}
|
|
|
|
|
2013-11-25 06:00:26 +01:00
|
|
|
@Override
|
|
|
|
public void tick()
|
|
|
|
{
|
|
|
|
super.tick();
|
|
|
|
|
|
|
|
if(FMLCommonHandler.instance().getEffectiveSide().isServer())
|
|
|
|
{
|
|
|
|
if(transferDelay == 0)
|
|
|
|
{
|
2013-11-29 03:43:53 +01:00
|
|
|
didTransfer = false;
|
2013-11-25 06:00:26 +01:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
transferDelay--;
|
|
|
|
}
|
|
|
|
|
2013-12-17 20:57:19 +01:00
|
|
|
if(Math.abs(getScale()-definedScale) > 0.01 || (getScale() != prevScale && (getScale() == 0 || getScale() == 1)))
|
2013-12-14 21:30:41 +01:00
|
|
|
{
|
|
|
|
needsUpdate = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
prevScale = getScale();
|
|
|
|
|
2013-11-29 03:43:53 +01:00
|
|
|
if(didTransfer != prevTransfer || needsUpdate)
|
2013-11-25 06:00:26 +01:00
|
|
|
{
|
2013-12-17 20:39:30 +01:00
|
|
|
MinecraftForge.EVENT_BUS.post(new FluidTransferEvent(this, fluidStored != null ? fluidStored.getFluid().getID() : -1, didTransfer, getScale()));
|
2013-11-29 03:43:53 +01:00
|
|
|
needsUpdate = false;
|
2013-12-17 20:57:19 +01:00
|
|
|
definedScale = getScale();
|
2013-11-25 06:00:26 +01:00
|
|
|
}
|
|
|
|
|
2013-11-29 03:43:53 +01:00
|
|
|
prevTransfer = didTransfer;
|
2013-12-14 06:36:52 +01:00
|
|
|
|
|
|
|
if(fluidStored != null)
|
|
|
|
{
|
2013-12-15 06:03:45 +01:00
|
|
|
fluidStored.amount -= tickEmit(fluidStored, true);
|
2013-12-14 06:36:52 +01:00
|
|
|
|
|
|
|
if(fluidStored.amount <= 0)
|
|
|
|
{
|
|
|
|
fluidStored = null;
|
|
|
|
}
|
|
|
|
}
|
2013-11-29 03:43:53 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void clientTick()
|
|
|
|
{
|
|
|
|
super.clientTick();
|
|
|
|
|
2013-12-17 20:45:30 +01:00
|
|
|
fluidScale = Math.max(fluidScale, definedScale);
|
|
|
|
|
2013-11-29 03:43:53 +01:00
|
|
|
if(didTransfer && fluidScale < 1)
|
|
|
|
{
|
2013-12-14 21:30:41 +01:00
|
|
|
fluidScale = Math.max(definedScale, Math.min(1, fluidScale+0.02F));
|
2013-11-29 03:43:53 +01:00
|
|
|
}
|
|
|
|
else if(!didTransfer && fluidScale > 0)
|
|
|
|
{
|
2013-12-14 21:30:41 +01:00
|
|
|
fluidScale = Math.max(definedScale, Math.max(0, fluidScale-0.02F));
|
2013-11-29 03:43:53 +01:00
|
|
|
|
|
|
|
if(fluidScale == 0)
|
|
|
|
{
|
|
|
|
refFluid = null;
|
|
|
|
}
|
2013-11-25 06:00:26 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-18 22:51:47 +02:00
|
|
|
@Override
|
2013-10-20 06:04:11 +02:00
|
|
|
public synchronized Set<IFluidHandler> getAcceptors(Object... data)
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-08-18 22:51:47 +02:00
|
|
|
FluidStack fluidToSend = (FluidStack)data[0];
|
2013-07-20 18:10:14 +02:00
|
|
|
Set<IFluidHandler> toReturn = new HashSet<IFluidHandler>();
|
2013-06-26 23:49:47 +02:00
|
|
|
|
2013-07-20 18:10:14 +02:00
|
|
|
for(IFluidHandler acceptor : possibleAcceptors)
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-12-12 22:54:55 +01:00
|
|
|
if(acceptorDirections.get(acceptor) == null)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2013-07-20 18:10:14 +02:00
|
|
|
if(acceptor.canFill(acceptorDirections.get(acceptor).getOpposite(), fluidToSend.getFluid()))
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-07-28 01:32:46 +02:00
|
|
|
toReturn.add(acceptor);
|
2013-06-26 23:49:47 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return toReturn;
|
|
|
|
}
|
2013-08-18 22:51:47 +02:00
|
|
|
|
|
|
|
@Override
|
2013-10-20 06:04:11 +02:00
|
|
|
public synchronized void refresh()
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-12-06 13:57:26 +01:00
|
|
|
Set<ITransmitter<FluidNetwork>> iterPipes = (Set<ITransmitter<FluidNetwork>>)transmitters.clone();
|
2013-08-04 02:41:16 +02:00
|
|
|
Iterator it = iterPipes.iterator();
|
2013-06-26 23:49:47 +02:00
|
|
|
|
|
|
|
possibleAcceptors.clear();
|
|
|
|
acceptorDirections.clear();
|
|
|
|
|
|
|
|
while(it.hasNext())
|
|
|
|
{
|
2013-12-06 13:57:26 +01:00
|
|
|
ITransmitter<FluidNetwork> conductor = (ITransmitter<FluidNetwork>)it.next();
|
2013-06-26 23:49:47 +02:00
|
|
|
|
2013-08-04 02:41:16 +02:00
|
|
|
if(conductor == null || ((TileEntity)conductor).isInvalid())
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
|
|
|
it.remove();
|
2013-08-17 19:32:05 +02:00
|
|
|
transmitters.remove(conductor);
|
2013-06-26 23:49:47 +02:00
|
|
|
}
|
|
|
|
else {
|
2013-08-27 01:04:00 +02:00
|
|
|
conductor.setTransmitterNetwork(this);
|
2013-06-26 23:49:47 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-12-06 13:57:26 +01:00
|
|
|
for(ITransmitter<FluidNetwork> pipe : iterPipes)
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-08-27 00:49:32 +02:00
|
|
|
if(pipe instanceof TileEntityMechanicalPipe && ((TileEntityMechanicalPipe)pipe).isActive) continue;
|
2013-11-24 22:44:16 +01:00
|
|
|
|
2013-07-20 18:10:14 +02:00
|
|
|
IFluidHandler[] acceptors = PipeUtils.getConnectedAcceptors((TileEntity)pipe);
|
2013-06-26 23:49:47 +02:00
|
|
|
|
2013-07-20 18:10:14 +02:00
|
|
|
for(IFluidHandler acceptor : acceptors)
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-08-19 03:32:47 +02:00
|
|
|
if(acceptor != null && !(acceptor instanceof ITransmitter))
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
|
|
|
possibleAcceptors.add(acceptor);
|
|
|
|
acceptorDirections.put(acceptor, ForgeDirection.getOrientation(Arrays.asList(acceptors).indexOf(acceptor)));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-18 22:51:47 +02:00
|
|
|
@Override
|
2013-10-20 06:04:11 +02:00
|
|
|
public synchronized void merge(FluidNetwork network)
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
|
|
|
if(network != null && network != this)
|
|
|
|
{
|
2013-08-04 02:41:16 +02:00
|
|
|
Set<FluidNetwork> networks = new HashSet<FluidNetwork>();
|
|
|
|
networks.add(this);
|
|
|
|
networks.add(network);
|
2013-11-29 03:43:53 +01:00
|
|
|
FluidNetwork newNetwork = create(networks);
|
2013-06-26 23:49:47 +02:00
|
|
|
newNetwork.refresh();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-20 18:10:14 +02:00
|
|
|
public static class FluidTransferEvent extends Event
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-07-20 18:10:14 +02:00
|
|
|
public final FluidNetwork fluidNetwork;
|
2013-06-26 23:49:47 +02:00
|
|
|
|
2013-11-25 06:00:26 +01:00
|
|
|
public final int fluidType;
|
2013-11-29 03:43:53 +01:00
|
|
|
public final boolean didTransfer;
|
2013-12-14 21:30:41 +01:00
|
|
|
public final float fluidScale;
|
2013-06-26 23:49:47 +02:00
|
|
|
|
2013-12-14 21:30:41 +01:00
|
|
|
public FluidTransferEvent(FluidNetwork network, int type, boolean did, float scale)
|
2013-06-26 23:49:47 +02:00
|
|
|
{
|
2013-07-20 18:10:14 +02:00
|
|
|
fluidNetwork = network;
|
2013-11-25 06:00:26 +01:00
|
|
|
fluidType = type;
|
2013-11-29 03:43:53 +01:00
|
|
|
didTransfer = did;
|
2013-12-14 21:30:41 +01:00
|
|
|
fluidScale = scale;
|
2013-06-26 23:49:47 +02:00
|
|
|
}
|
|
|
|
}
|
2013-12-14 21:30:41 +01:00
|
|
|
|
|
|
|
public float getScale()
|
|
|
|
{
|
2013-12-17 19:23:29 +01:00
|
|
|
return (fluidStored == null || getCapacity() == 0 ? 0 : (float)fluidStored.amount/getCapacity());
|
2013-12-14 21:30:41 +01:00
|
|
|
}
|
2013-08-04 02:18:43 +02:00
|
|
|
|
2013-06-26 23:49:47 +02:00
|
|
|
@Override
|
|
|
|
public String toString()
|
|
|
|
{
|
2013-08-17 19:32:05 +02:00
|
|
|
return "[FluidNetwork] " + transmitters.size() + " transmitters, " + possibleAcceptors.size() + " acceptors.";
|
2013-08-04 02:18:43 +02:00
|
|
|
}
|
2013-08-22 17:36:31 +02:00
|
|
|
|
|
|
|
@Override
|
2013-12-06 13:57:26 +01:00
|
|
|
protected FluidNetwork create(ITransmitter<FluidNetwork>... varTransmitters)
|
2013-08-22 17:36:31 +02:00
|
|
|
{
|
2013-11-29 03:43:53 +01:00
|
|
|
FluidNetwork network = new FluidNetwork(varTransmitters);
|
|
|
|
network.refFluid = refFluid;
|
|
|
|
network.fluidScale = fluidScale;
|
2013-12-17 18:53:33 +01:00
|
|
|
|
|
|
|
if(fluidStored != null)
|
|
|
|
{
|
|
|
|
if(network.fluidStored == null)
|
|
|
|
{
|
|
|
|
network.fluidStored = fluidStored;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
network.fluidStored.amount += fluidStored.amount;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-29 03:43:53 +01:00
|
|
|
return network;
|
2013-08-22 17:36:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2013-12-06 13:57:26 +01:00
|
|
|
protected FluidNetwork create(Collection<ITransmitter<FluidNetwork>> collection)
|
2013-08-22 17:36:31 +02:00
|
|
|
{
|
2013-11-29 03:43:53 +01:00
|
|
|
FluidNetwork network = new FluidNetwork(collection);
|
|
|
|
network.refFluid = refFluid;
|
|
|
|
network.fluidScale = fluidScale;
|
2013-12-17 18:53:33 +01:00
|
|
|
|
|
|
|
if(fluidStored != null)
|
|
|
|
{
|
|
|
|
if(network.fluidStored == null)
|
|
|
|
{
|
|
|
|
network.fluidStored = fluidStored;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
network.fluidStored.amount += fluidStored.amount;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-29 03:43:53 +01:00
|
|
|
return network;
|
2013-08-22 17:36:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected FluidNetwork create(Set<FluidNetwork> networks)
|
|
|
|
{
|
2013-12-17 18:53:33 +01:00
|
|
|
return new FluidNetwork(networks);
|
2013-08-22 17:36:31 +02:00
|
|
|
}
|
2013-08-22 20:07:28 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public TransmissionType getTransmissionType()
|
|
|
|
{
|
|
|
|
return TransmissionType.FLUID;
|
|
|
|
}
|
2013-08-23 20:23:08 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getNeeded()
|
|
|
|
{
|
2013-12-14 06:36:52 +01:00
|
|
|
return "Fluid needed (any type): " + (float)getFluidNeeded()/1000F + " buckets";
|
2013-08-23 20:23:08 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getFlow()
|
|
|
|
{
|
2013-12-16 16:54:20 +01:00
|
|
|
return fluidStored == null ? "None" : fluidStored.getFluid().getLocalizedName() + ", " + fluidStored.amount + "mB/tick";
|
2013-08-23 20:23:08 +02:00
|
|
|
}
|
2013-06-26 23:49:47 +02:00
|
|
|
}
|