First draft handling sided tanks
This commit is contained in:
parent
252ed9df9d
commit
98be088256
10 changed files with 16 additions and 13 deletions
|
@ -12,6 +12,7 @@ import buildcraft.core.IMachine;
|
||||||
import net.minecraft.src.Block;
|
import net.minecraft.src.Block;
|
||||||
import net.minecraft.src.IInventory;
|
import net.minecraft.src.IInventory;
|
||||||
import net.minecraft.src.TileEntity;
|
import net.minecraft.src.TileEntity;
|
||||||
|
import net.minecraftforge.common.ForgeDirection;
|
||||||
import net.minecraftforge.liquids.ITankContainer;
|
import net.minecraftforge.liquids.ITankContainer;
|
||||||
|
|
||||||
public class DefaultTriggerProvider implements ITriggerProvider {
|
public class DefaultTriggerProvider implements ITriggerProvider {
|
||||||
|
@ -30,7 +31,7 @@ public class DefaultTriggerProvider implements ITriggerProvider {
|
||||||
res.add(BuildCraftCore.triggerFullInventory);
|
res.add(BuildCraftCore.triggerFullInventory);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tile instanceof ITankContainer && ((ITankContainer) tile).getTanks().length > 0) {
|
if (tile instanceof ITankContainer && ((ITankContainer) tile).getTanks(ForgeDirection.UNKNOWN).length > 0) {
|
||||||
res.add(BuildCraftCore.triggerEmptyLiquid);
|
res.add(BuildCraftCore.triggerEmptyLiquid);
|
||||||
res.add(BuildCraftCore.triggerContainsLiquid);
|
res.add(BuildCraftCore.triggerContainsLiquid);
|
||||||
res.add(BuildCraftCore.triggerSpaceLiquid);
|
res.add(BuildCraftCore.triggerSpaceLiquid);
|
||||||
|
|
|
@ -13,6 +13,7 @@ import buildcraft.api.gates.ITriggerParameter;
|
||||||
import buildcraft.api.gates.Trigger;
|
import buildcraft.api.gates.Trigger;
|
||||||
import buildcraft.core.DefaultProps;
|
import buildcraft.core.DefaultProps;
|
||||||
import net.minecraft.src.TileEntity;
|
import net.minecraft.src.TileEntity;
|
||||||
|
import net.minecraftforge.common.ForgeDirection;
|
||||||
import net.minecraftforge.liquids.ILiquidTank;
|
import net.minecraftforge.liquids.ILiquidTank;
|
||||||
import net.minecraftforge.liquids.ITankContainer;
|
import net.minecraftforge.liquids.ITankContainer;
|
||||||
import net.minecraftforge.liquids.LiquidManager;
|
import net.minecraftforge.liquids.LiquidManager;
|
||||||
|
@ -76,7 +77,7 @@ public class TriggerLiquidContainer extends Trigger {
|
||||||
if (parameter != null && parameter.getItem() != null)
|
if (parameter != null && parameter.getItem() != null)
|
||||||
seachedLiquidId = LiquidManager.getLiquidIDForFilledItem(parameter.getItem());
|
seachedLiquidId = LiquidManager.getLiquidIDForFilledItem(parameter.getItem());
|
||||||
|
|
||||||
ILiquidTank[] liquids = container.getTanks();
|
ILiquidTank[] liquids = container.getTanks(ForgeDirection.UNKNOWN);
|
||||||
|
|
||||||
if (liquids == null || liquids.length == 0)
|
if (liquids == null || liquids.length == 0)
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -468,7 +468,7 @@ public class TileEngine extends TileBuildCraft implements IPowerReceptor, IInven
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public LiquidTank[] getTanks() {
|
public LiquidTank[] getTanks(ForgeDirection direction) {
|
||||||
if (engine == null) {
|
if (engine == null) {
|
||||||
return new LiquidTank[0];
|
return new LiquidTank[0];
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -111,7 +111,7 @@ public class BlockTank extends BlockContainer {
|
||||||
// Handle empty containers
|
// Handle empty containers
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
LiquidStack available = tank.getTanks()[0].getLiquid();
|
LiquidStack available = tank.getTanks(ForgeDirection.UNKNOWN)[0].getLiquid();
|
||||||
if(available != null){
|
if(available != null){
|
||||||
ItemStack filled = LiquidManager.fillLiquidContainer(available, current);
|
ItemStack filled = LiquidManager.fillLiquidContainer(available, current);
|
||||||
|
|
||||||
|
|
|
@ -449,7 +449,7 @@ public class TileRefinery extends TileMachine implements ITankContainer, IPowerR
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ILiquidTank[] getTanks() {
|
public ILiquidTank[] getTanks(ForgeDirection direction) {
|
||||||
return new ILiquidTank[] {
|
return new ILiquidTank[] {
|
||||||
new LiquidTank(slot1.liquidId, slot1.quantity, LIQUID_PER_SLOT),
|
new LiquidTank(slot1.liquidId, slot1.quantity, LIQUID_PER_SLOT),
|
||||||
new LiquidTank(slot2.liquidId, slot2.quantity, LIQUID_PER_SLOT),
|
new LiquidTank(slot2.liquidId, slot2.quantity, LIQUID_PER_SLOT),
|
||||||
|
|
|
@ -223,7 +223,7 @@ public class TileTank extends TileBuildCraft implements ITankContainer
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ILiquidTank[] getTanks()
|
public ILiquidTank[] getTanks(ForgeDirection direction)
|
||||||
{
|
{
|
||||||
ILiquidTank compositeTank = new LiquidTank(tank.getCapacity());
|
ILiquidTank compositeTank = new LiquidTank(tank.getCapacity());
|
||||||
|
|
||||||
|
|
|
@ -406,7 +406,7 @@ public class PipeTransportLiquids extends PipeTransport implements ITankContaine
|
||||||
if (tile instanceof ITankContainer) {
|
if (tile instanceof ITankContainer) {
|
||||||
ITankContainer liq = (ITankContainer) tile;
|
ITankContainer liq = (ITankContainer) tile;
|
||||||
|
|
||||||
if (liq.getTanks() != null && liq.getTanks().length > 0)
|
if (liq.getTanks(ForgeDirection.UNKNOWN) != null && liq.getTanks(ForgeDirection.UNKNOWN).length > 0)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -460,7 +460,7 @@ public class PipeTransportLiquids extends PipeTransport implements ITankContaine
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ILiquidTank[] getTanks() {
|
public ILiquidTank[] getTanks(ForgeDirection direction) {
|
||||||
return internalTanks;
|
return internalTanks;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -546,9 +546,9 @@ public class TileGenericPipe extends TileEntity implements IPowerReceptor, ITank
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ILiquidTank[] getTanks() {
|
public ILiquidTank[] getTanks(ForgeDirection direction) {
|
||||||
if (BlockGenericPipe.isValid(pipe) && pipe.transport instanceof ITankContainer)
|
if (BlockGenericPipe.isValid(pipe) && pipe.transport instanceof ITankContainer)
|
||||||
return ((ITankContainer) pipe.transport).getTanks();
|
return ((ITankContainer) pipe.transport).getTanks(ForgeDirection.UNKNOWN);
|
||||||
else
|
else
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,6 +41,6 @@ public class PipeLiquidsSandstone extends Pipe implements IPipeTransportLiquidsH
|
||||||
if (!(container.tileBuffer[from.ordinal()].getTile() instanceof TileGenericPipe))
|
if (!(container.tileBuffer[from.ordinal()].getTile() instanceof TileGenericPipe))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
return ((PipeTransportLiquids)this.transport).getTanks()[from.ordinal()].fill(resource, doFill);
|
return ((PipeTransportLiquids)this.transport).getTanks(ForgeDirection.UNKNOWN)[from.ordinal()].fill(resource, doFill);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
package buildcraft.transport.triggers;
|
package buildcraft.transport.triggers;
|
||||||
|
|
||||||
|
import net.minecraftforge.common.ForgeDirection;
|
||||||
import net.minecraftforge.liquids.ILiquidTank;
|
import net.minecraftforge.liquids.ILiquidTank;
|
||||||
import net.minecraftforge.liquids.LiquidManager;
|
import net.minecraftforge.liquids.LiquidManager;
|
||||||
import net.minecraftforge.liquids.LiquidStack;
|
import net.minecraftforge.liquids.LiquidStack;
|
||||||
|
@ -102,13 +103,13 @@ public class TriggerPipeContents extends Trigger implements ITriggerPipe {
|
||||||
searchedLiquid = LiquidManager.getLiquidForFilledItem(parameter.getItem());
|
searchedLiquid = LiquidManager.getLiquidForFilledItem(parameter.getItem());
|
||||||
|
|
||||||
if (kind == Kind.Empty) {
|
if (kind == Kind.Empty) {
|
||||||
for (ILiquidTank b : transportLiquids.getTanks())
|
for (ILiquidTank b : transportLiquids.getTanks(ForgeDirection.UNKNOWN))
|
||||||
if (b.getLiquid() != null && b.getLiquid().amount != 0)
|
if (b.getLiquid() != null && b.getLiquid().amount != 0)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
for (ILiquidTank b : transportLiquids.getTanks())
|
for (ILiquidTank b : transportLiquids.getTanks(ForgeDirection.UNKNOWN))
|
||||||
if (b.getLiquid() != null && b.getLiquid().amount != 0)
|
if (b.getLiquid() != null && b.getLiquid().amount != 0)
|
||||||
if (searchedLiquid == null || searchedLiquid.isLiquidEqual(b.getLiquid()))
|
if (searchedLiquid == null || searchedLiquid.isLiquidEqual(b.getLiquid()))
|
||||||
return true;
|
return true;
|
||||||
|
|
Loading…
Reference in a new issue