initial resurection of stripes pipe, for #1491
This commit is contained in:
parent
63d4a5a055
commit
5822a0806a
7 changed files with 240 additions and 42 deletions
|
@ -81,6 +81,7 @@ import buildcraft.transport.pipes.PipeItemsObsidian;
|
||||||
import buildcraft.transport.pipes.PipeItemsQuartz;
|
import buildcraft.transport.pipes.PipeItemsQuartz;
|
||||||
import buildcraft.transport.pipes.PipeItemsSandstone;
|
import buildcraft.transport.pipes.PipeItemsSandstone;
|
||||||
import buildcraft.transport.pipes.PipeItemsStone;
|
import buildcraft.transport.pipes.PipeItemsStone;
|
||||||
|
import buildcraft.transport.pipes.PipeItemsStripes;
|
||||||
import buildcraft.transport.pipes.PipeItemsVoid;
|
import buildcraft.transport.pipes.PipeItemsVoid;
|
||||||
import buildcraft.transport.pipes.PipeItemsWood;
|
import buildcraft.transport.pipes.PipeItemsWood;
|
||||||
import buildcraft.transport.pipes.PipePowerCobblestone;
|
import buildcraft.transport.pipes.PipePowerCobblestone;
|
||||||
|
@ -140,6 +141,7 @@ public class BuildCraftTransport extends BuildCraftMod {
|
||||||
public static Item pipeItemsVoid;
|
public static Item pipeItemsVoid;
|
||||||
public static Item pipeItemsSandstone;
|
public static Item pipeItemsSandstone;
|
||||||
public static Item pipeItemsEmzuli;
|
public static Item pipeItemsEmzuli;
|
||||||
|
public static Item pipeItemsStripes;
|
||||||
public static Item pipeFluidsWood;
|
public static Item pipeFluidsWood;
|
||||||
public static Item pipeFluidsCobblestone;
|
public static Item pipeFluidsCobblestone;
|
||||||
public static Item pipeFluidsStone;
|
public static Item pipeFluidsStone;
|
||||||
|
@ -333,6 +335,7 @@ public class BuildCraftTransport extends BuildCraftMod {
|
||||||
pipeItemsSandstone = buildPipe(DefaultProps.PIPE_ITEMS_SANDSTONE_ID, PipeItemsSandstone.class, "Sandstone Transport Pipe", CreativeTabBuildCraft.TIER_1, Blocks.sandstone, Blocks.glass, Blocks.sandstone);
|
pipeItemsSandstone = buildPipe(DefaultProps.PIPE_ITEMS_SANDSTONE_ID, PipeItemsSandstone.class, "Sandstone Transport Pipe", CreativeTabBuildCraft.TIER_1, Blocks.sandstone, Blocks.glass, Blocks.sandstone);
|
||||||
pipeItemsVoid = buildPipe(DefaultProps.PIPE_ITEMS_VOID_ID, PipeItemsVoid.class, "Void Transport Pipe", CreativeTabBuildCraft.TIER_1, "dyeBlack", Blocks.glass, Items.redstone);
|
pipeItemsVoid = buildPipe(DefaultProps.PIPE_ITEMS_VOID_ID, PipeItemsVoid.class, "Void Transport Pipe", CreativeTabBuildCraft.TIER_1, "dyeBlack", Blocks.glass, Items.redstone);
|
||||||
pipeItemsEmzuli = buildPipe(DefaultProps.PIPE_ITEMS_EMZULI_ID, PipeItemsEmzuli.class, "Emzuli Transport Pipe", CreativeTabBuildCraft.MISC, Blocks.lapis_block, Blocks.glass, Items.emerald);
|
pipeItemsEmzuli = buildPipe(DefaultProps.PIPE_ITEMS_EMZULI_ID, PipeItemsEmzuli.class, "Emzuli Transport Pipe", CreativeTabBuildCraft.MISC, Blocks.lapis_block, Blocks.glass, Items.emerald);
|
||||||
|
pipeItemsStripes = buildPipe(0, PipeItemsStripes.class, "Stripes Transport Pipe", CreativeTabBuildCraft.TIER_3, Items.dye, Blocks.glass, Items.dye);
|
||||||
|
|
||||||
pipeFluidsWood = buildPipe(DefaultProps.PIPE_LIQUIDS_WOOD_ID, PipeFluidsWood.class, "Wooden Waterproof Pipe", CreativeTabBuildCraft.TIER_2, pipeWaterproof, pipeItemsWood);
|
pipeFluidsWood = buildPipe(DefaultProps.PIPE_LIQUIDS_WOOD_ID, PipeFluidsWood.class, "Wooden Waterproof Pipe", CreativeTabBuildCraft.TIER_2, pipeWaterproof, pipeItemsWood);
|
||||||
pipeFluidsCobblestone = buildPipe(DefaultProps.PIPE_LIQUIDS_COBBLESTONE_ID, PipeFluidsCobblestone.class, "Cobblestone Waterproof Pipe", CreativeTabBuildCraft.TIER_2, pipeWaterproof, pipeItemsCobblestone);
|
pipeFluidsCobblestone = buildPipe(DefaultProps.PIPE_LIQUIDS_COBBLESTONE_ID, PipeFluidsCobblestone.class, "Cobblestone Waterproof Pipe", CreativeTabBuildCraft.TIER_2, pipeWaterproof, pipeItemsCobblestone);
|
||||||
|
|
|
@ -27,7 +27,6 @@ import net.minecraft.world.WorldSettings.GameType;
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import buildcraft.BuildCraftTransport;
|
import buildcraft.BuildCraftTransport;
|
||||||
import buildcraft.api.core.IIconProvider;
|
import buildcraft.api.core.IIconProvider;
|
||||||
import buildcraft.api.core.SafeTimeTracker;
|
|
||||||
import buildcraft.api.gates.IAction;
|
import buildcraft.api.gates.IAction;
|
||||||
import buildcraft.api.gates.ITrigger;
|
import buildcraft.api.gates.ITrigger;
|
||||||
import buildcraft.api.transport.PipeWire;
|
import buildcraft.api.transport.PipeWire;
|
||||||
|
@ -51,7 +50,6 @@ public abstract class Pipe<T extends PipeTransport> implements IDropControlInven
|
||||||
public Gate gate;
|
public Gate gate;
|
||||||
@SuppressWarnings("rawtypes")
|
@SuppressWarnings("rawtypes")
|
||||||
private static Map<Class, TilePacketWrapper> networkWrappers = new HashMap<Class, TilePacketWrapper>();
|
private static Map<Class, TilePacketWrapper> networkWrappers = new HashMap<Class, TilePacketWrapper>();
|
||||||
public SafeTimeTracker actionTracker = new SafeTimeTracker();
|
|
||||||
private static Map<Class<? extends Pipe>, Map<Class<? extends PipeEvent>, EventHandler>> eventHandlers = new HashMap<Class<? extends Pipe>, Map<Class<? extends PipeEvent>, EventHandler>>();
|
private static Map<Class<? extends Pipe>, Map<Class<? extends PipeEvent>, EventHandler>> eventHandlers = new HashMap<Class<? extends Pipe>, Map<Class<? extends PipeEvent>, EventHandler>>();
|
||||||
|
|
||||||
public Pipe(T transport, Item item) {
|
public Pipe(T transport, Item item) {
|
||||||
|
@ -65,9 +63,7 @@ public abstract class Pipe<T extends PipeTransport> implements IDropControlInven
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setTile(TileEntity tile) {
|
public void setTile(TileEntity tile) {
|
||||||
|
|
||||||
this.container = (TileGenericPipe) tile;
|
this.container = (TileGenericPipe) tile;
|
||||||
|
|
||||||
transport.setTile((TileGenericPipe) tile);
|
transport.setTile((TileGenericPipe) tile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -154,8 +154,9 @@ public class PipeIconProvider implements IIconProvider {
|
||||||
@Override
|
@Override
|
||||||
@SideOnly(Side.CLIENT)
|
@SideOnly(Side.CLIENT)
|
||||||
public IIcon getIcon(int pipeIconIndex) {
|
public IIcon getIcon(int pipeIconIndex) {
|
||||||
if (pipeIconIndex == -1)
|
if (pipeIconIndex == -1) {
|
||||||
return null;
|
return null;
|
||||||
|
}
|
||||||
return TYPE.VALUES[pipeIconIndex].icon;
|
return TYPE.VALUES[pipeIconIndex].icon;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -59,8 +59,9 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
}
|
}
|
||||||
PipeEventItem.AdjustSpeed event = new PipeEventItem.AdjustSpeed(item);
|
PipeEventItem.AdjustSpeed event = new PipeEventItem.AdjustSpeed(item);
|
||||||
container.pipe.handlePipeEvent(event);
|
container.pipe.handlePipeEvent(event);
|
||||||
if (!event.handled)
|
if (!event.handled) {
|
||||||
defaultReajustSpeed(item);
|
defaultReajustSpeed(item);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void defaultReajustSpeed(TravelingItem item) {
|
public void defaultReajustSpeed(TravelingItem item) {
|
||||||
|
@ -90,10 +91,11 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void injectItem(TravelingItem item, ForgeDirection inputOrientation) {
|
public void injectItem(TravelingItem item, ForgeDirection inputOrientation) {
|
||||||
if (item.isCorrupted())
|
if (item.isCorrupted()) {
|
||||||
// Safe guard - if for any reason the item is corrupted at this
|
// Safe guard - if for any reason the item is corrupted at this
|
||||||
// stage, avoid adding it to the pipe to avoid further exceptions.
|
// stage, avoid adding it to the pipe to avoid further exceptions.
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
item.reset();
|
item.reset();
|
||||||
item.input = inputOrientation;
|
item.input = inputOrientation;
|
||||||
|
@ -112,16 +114,18 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
|
|
||||||
PipeEventItem.Entered event = new PipeEventItem.Entered(item);
|
PipeEventItem.Entered event = new PipeEventItem.Entered(item);
|
||||||
container.pipe.handlePipeEvent(event);
|
container.pipe.handlePipeEvent(event);
|
||||||
if (event.cancelled)
|
if (event.cancelled) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
items.add(item);
|
items.add(item);
|
||||||
|
|
||||||
if (!container.getWorldObj().isRemote) {
|
if (!container.getWorldObj().isRemote) {
|
||||||
sendTravelerPacket(item, false);
|
sendTravelerPacket(item, false);
|
||||||
|
|
||||||
if (items.size() > BuildCraftTransport.groupItemsTrigger)
|
if (items.size() > BuildCraftTransport.groupItemsTrigger) {
|
||||||
groupEntities();
|
groupEntities();
|
||||||
|
}
|
||||||
|
|
||||||
if (items.size() > MAX_PIPE_STACKS) {
|
if (items.size() > MAX_PIPE_STACKS) {
|
||||||
BCLog.logger.log(Level.WARNING, String.format("Pipe exploded at %d,%d,%d because it had too many stacks: %d", container.xCoord, container.yCoord, container.zCoord, items.size()));
|
BCLog.logger.log(Level.WARNING, String.format("Pipe exploded at %d,%d,%d because it had too many stacks: %d", container.xCoord, container.yCoord, container.zCoord, items.size()));
|
||||||
|
@ -132,8 +136,9 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
int numItems = 0;
|
int numItems = 0;
|
||||||
for (TravelingItem travellingItem : items) {
|
for (TravelingItem travellingItem : items) {
|
||||||
ItemStack stack = travellingItem.getItemStack();
|
ItemStack stack = travellingItem.getItemStack();
|
||||||
if (stack != null && stack.stackSize > 0)
|
if (stack != null && stack.stackSize > 0) {
|
||||||
numItems += stack.stackSize;
|
numItems += stack.stackSize;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (numItems > MAX_PIPE_ITEMS) {
|
if (numItems > MAX_PIPE_ITEMS) {
|
||||||
|
@ -154,10 +159,11 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
* @param item
|
* @param item
|
||||||
*/
|
*/
|
||||||
protected void reverseItem(TravelingItem item) {
|
protected void reverseItem(TravelingItem item) {
|
||||||
if (item.isCorrupted())
|
if (item.isCorrupted()) {
|
||||||
// Safe guard - if for any reason the item is corrupted at this
|
// Safe guard - if for any reason the item is corrupted at this
|
||||||
// stage, avoid adding it to the pipe to avoid further exceptions.
|
// stage, avoid adding it to the pipe to avoid further exceptions.
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
item.toCenter = true;
|
item.toCenter = true;
|
||||||
item.input = item.output.getOpposite();
|
item.input = item.output.getOpposite();
|
||||||
|
@ -174,20 +180,23 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
}
|
}
|
||||||
PipeEventItem.Entered event = new PipeEventItem.Entered(item);
|
PipeEventItem.Entered event = new PipeEventItem.Entered(item);
|
||||||
container.pipe.handlePipeEvent(event);
|
container.pipe.handlePipeEvent(event);
|
||||||
if (event.cancelled)
|
if (event.cancelled) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
items.unscheduleRemoval(item);
|
items.unscheduleRemoval(item);
|
||||||
|
|
||||||
if (!container.getWorldObj().isRemote)
|
if (!container.getWorldObj().isRemote) {
|
||||||
sendTravelerPacket(item, true);
|
sendTravelerPacket(item, true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ForgeDirection resolveDestination(TravelingItem data) {
|
public ForgeDirection resolveDestination(TravelingItem data) {
|
||||||
List<ForgeDirection> validDestinations = getPossibleMovements(data);
|
List<ForgeDirection> validDestinations = getPossibleMovements(data);
|
||||||
|
|
||||||
if (validDestinations.isEmpty())
|
if (validDestinations.isEmpty()) {
|
||||||
return ForgeDirection.UNKNOWN;
|
return ForgeDirection.UNKNOWN;
|
||||||
|
}
|
||||||
|
|
||||||
return validDestinations.get(0);
|
return validDestinations.get(0);
|
||||||
}
|
}
|
||||||
|
@ -205,8 +214,9 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
sides.remove(ForgeDirection.UNKNOWN);
|
sides.remove(ForgeDirection.UNKNOWN);
|
||||||
|
|
||||||
for (ForgeDirection o : sides) {
|
for (ForgeDirection o : sides) {
|
||||||
if (container.pipe.outputOpen(o) && canReceivePipeObjects(o, item))
|
if (container.pipe.outputOpen(o) && canReceivePipeObjects(o, item)) {
|
||||||
result.add(o);
|
result.add(o);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.container.pipe instanceof IPipeTransportItemsHook) {
|
if (this.container.pipe instanceof IPipeTransportItemsHook) {
|
||||||
|
@ -230,16 +240,19 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
public boolean canReceivePipeObjects(ForgeDirection o, TravelingItem item) {
|
public boolean canReceivePipeObjects(ForgeDirection o, TravelingItem item) {
|
||||||
TileEntity entity = container.getTile(o);
|
TileEntity entity = container.getTile(o);
|
||||||
|
|
||||||
if (!container.isPipeConnected(o))
|
if (!container.isPipeConnected(o)) {
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (entity instanceof TileGenericPipe) {
|
if (entity instanceof TileGenericPipe) {
|
||||||
TileGenericPipe pipe = (TileGenericPipe) entity;
|
TileGenericPipe pipe = (TileGenericPipe) entity;
|
||||||
|
|
||||||
return pipe.pipe.transport instanceof PipeTransportItems;
|
return pipe.pipe.transport instanceof PipeTransportItems;
|
||||||
} else if (entity instanceof IInventory && item.getInsertionHandler().canInsertItem(item, (IInventory) entity))
|
} else if (entity instanceof IInventory && item.getInsertionHandler().canInsertItem(item, (IInventory) entity)) {
|
||||||
if (Transactor.getTransactorFor(entity).add(item.getItemStack(), o.getOpposite(), false).stackSize > 0)
|
if (Transactor.getTransactorFor(entity).add(item.getItemStack(), o.getOpposite(), false).stackSize > 0) {
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -275,8 +288,9 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
item.setPosition(container.xCoord + 0.5, container.yCoord + TransportUtils.getPipeFloorOf(item.getItemStack()), container.zCoord + 0.5);
|
item.setPosition(container.xCoord + 0.5, container.yCoord + TransportUtils.getPipeFloorOf(item.getItemStack()), container.zCoord + 0.5);
|
||||||
|
|
||||||
if (item.output == ForgeDirection.UNKNOWN) {
|
if (item.output == ForgeDirection.UNKNOWN) {
|
||||||
if (items.scheduleRemoval(item))
|
if (items.scheduleRemoval(item)) {
|
||||||
dropItem(item);
|
dropItem(item);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (travelHook != null) {
|
if (travelHook != null) {
|
||||||
travelHook.centerReached(this, item);
|
travelHook.centerReached(this, item);
|
||||||
|
@ -332,13 +346,15 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
reverseItem(item);
|
reverseItem(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else
|
} else {
|
||||||
dropItem(item);
|
dropItem(item);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void dropItem(TravelingItem item) {
|
private void dropItem(TravelingItem item) {
|
||||||
if (container.getWorldObj().isRemote)
|
if (container.getWorldObj().isRemote) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (travelHook != null) {
|
if (travelHook != null) {
|
||||||
travelHook.drop(this, item);
|
travelHook.drop(this, item);
|
||||||
|
@ -346,8 +362,11 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
|
|
||||||
PipeEventItem.DropItem event = new PipeEventItem.DropItem(item, item.toEntityItem());
|
PipeEventItem.DropItem event = new PipeEventItem.DropItem(item, item.toEntityItem());
|
||||||
container.pipe.handlePipeEvent(event);
|
container.pipe.handlePipeEvent(event);
|
||||||
if (event.entity == null)
|
|
||||||
|
if (event.entity == null) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
container.getWorldObj().spawnEntityInWorld(event.entity);
|
container.getWorldObj().spawnEntityInWorld(event.entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -381,8 +400,9 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
|
|
||||||
TravelingItem item = TravelingItem.make(dataTag);
|
TravelingItem item = TravelingItem.make(dataTag);
|
||||||
|
|
||||||
if (item.isCorrupted())
|
if (item.isCorrupted()) {
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
items.scheduleLoad(item);
|
items.scheduleLoad(item);
|
||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
|
@ -453,8 +473,9 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
public int getNumberOfItems() {
|
public int getNumberOfItems() {
|
||||||
int num = 0;
|
int num = 0;
|
||||||
for (TravelingItem item : items) {
|
for (TravelingItem item : items) {
|
||||||
if (item.getItemStack() == null)
|
if (item.getItemStack() == null) {
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
num += item.getItemStack().stackSize;
|
num += item.getItemStack().stackSize;
|
||||||
}
|
}
|
||||||
return num;
|
return num;
|
||||||
|
@ -467,8 +488,9 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
public boolean canPipeConnect(TileEntity tile, ForgeDirection side) {
|
public boolean canPipeConnect(TileEntity tile, ForgeDirection side) {
|
||||||
if (tile instanceof TileGenericPipe) {
|
if (tile instanceof TileGenericPipe) {
|
||||||
Pipe pipe2 = ((TileGenericPipe) tile).pipe;
|
Pipe pipe2 = ((TileGenericPipe) tile).pipe;
|
||||||
if (BlockGenericPipe.isValid(pipe2) && !(pipe2.transport instanceof PipeTransportItems))
|
if (BlockGenericPipe.isValid(pipe2) && !(pipe2.transport instanceof PipeTransportItems)) {
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tile instanceof ISidedInventory) {
|
if (tile instanceof ISidedInventory) {
|
||||||
|
@ -490,11 +512,13 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
*/
|
*/
|
||||||
public void groupEntities() {
|
public void groupEntities() {
|
||||||
for (TravelingItem item : items) {
|
for (TravelingItem item : items) {
|
||||||
if (item.isCorrupted())
|
if (item.isCorrupted()) {
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
for (TravelingItem otherItem : items) {
|
for (TravelingItem otherItem : items) {
|
||||||
if (item.tryMergeInto(otherItem))
|
if (item.tryMergeInto(otherItem)) {
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -504,8 +528,9 @@ public class PipeTransportItems extends PipeTransport {
|
||||||
groupEntities();
|
groupEntities();
|
||||||
|
|
||||||
for (TravelingItem item : items) {
|
for (TravelingItem item : items) {
|
||||||
if (!item.isCorrupted())
|
if (!item.isCorrupted()) {
|
||||||
container.pipe.dropItem(item.getItemStack());
|
container.pipe.dropItem(item.getItemStack());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
items.clear();
|
items.clear();
|
||||||
|
|
|
@ -10,9 +10,6 @@ package buildcraft.transport.pipes;
|
||||||
|
|
||||||
import io.netty.buffer.ByteBuf;
|
import io.netty.buffer.ByteBuf;
|
||||||
|
|
||||||
import java.io.DataInputStream;
|
|
||||||
import java.io.DataOutputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
|
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
|
@ -20,7 +17,6 @@ import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.inventory.IInventory;
|
import net.minecraft.inventory.IInventory;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.NBTBase;
|
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import buildcraft.BuildCraftTransport;
|
import buildcraft.BuildCraftTransport;
|
||||||
|
@ -29,7 +25,6 @@ import buildcraft.core.GuiIds;
|
||||||
import buildcraft.core.inventory.SimpleInventory;
|
import buildcraft.core.inventory.SimpleInventory;
|
||||||
import buildcraft.core.inventory.StackHelper;
|
import buildcraft.core.inventory.StackHelper;
|
||||||
import buildcraft.core.network.IClientState;
|
import buildcraft.core.network.IClientState;
|
||||||
import buildcraft.core.proxy.CoreProxy;
|
|
||||||
import buildcraft.core.utils.Utils;
|
import buildcraft.core.utils.Utils;
|
||||||
import buildcraft.transport.BlockGenericPipe;
|
import buildcraft.transport.BlockGenericPipe;
|
||||||
import buildcraft.transport.Pipe;
|
import buildcraft.transport.Pipe;
|
||||||
|
@ -86,9 +81,11 @@ public class PipeItemsDiamond extends Pipe<PipeTransportItems> implements IClien
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean blockActivated(EntityPlayer entityplayer) {
|
public boolean blockActivated(EntityPlayer entityplayer) {
|
||||||
if (entityplayer.getCurrentEquippedItem() != null)
|
if (entityplayer.getCurrentEquippedItem() != null) {
|
||||||
if (Block.getBlockFromItem(entityplayer.getCurrentEquippedItem().getItem()) instanceof BlockGenericPipe)
|
if (Block.getBlockFromItem(entityplayer.getCurrentEquippedItem().getItem()) instanceof BlockGenericPipe) {
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!container.getWorldObj().isRemote) {
|
if (!container.getWorldObj().isRemote) {
|
||||||
entityplayer.openGui(BuildCraftTransport.instance, GuiIds.PIPE_DIAMOND, container.getWorldObj(), container.xCoord, container.yCoord, container.zCoord);
|
entityplayer.openGui(BuildCraftTransport.instance, GuiIds.PIPE_DIAMOND, container.getWorldObj(), container.xCoord, container.yCoord, container.zCoord);
|
||||||
|
@ -111,20 +108,26 @@ public class PipeItemsDiamond extends Pipe<PipeTransportItems> implements IClien
|
||||||
for (int slot = 0; slot < 9; ++slot) {
|
for (int slot = 0; slot < 9; ++slot) {
|
||||||
ItemStack filter = getFilters().getStackInSlot(dir.ordinal() * 9 + slot);
|
ItemStack filter = getFilters().getStackInSlot(dir.ordinal() * 9 + slot);
|
||||||
|
|
||||||
if (filter != null)
|
if (filter != null) {
|
||||||
foundFilter = true;
|
foundFilter = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (StackHelper.instance().isMatchingItem(filter, event.item.getItemStack(), true, false))
|
if (StackHelper.instance().isMatchingItem(filter, event.item.getItemStack(), true, false)) {
|
||||||
filteredOrientations.add(dir);
|
filteredOrientations.add(dir);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (!foundFilter)
|
if (!foundFilter) {
|
||||||
defaultOrientations.add(dir);
|
defaultOrientations.add(dir);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
event.destinations.clear();
|
event.destinations.clear();
|
||||||
if (!filteredOrientations.isEmpty())
|
|
||||||
|
if (!filteredOrientations.isEmpty()) {
|
||||||
event.destinations.addAll(filteredOrientations);
|
event.destinations.addAll(filteredOrientations);
|
||||||
else
|
} else {
|
||||||
event.destinations.addAll(defaultOrientations);
|
event.destinations.addAll(defaultOrientations);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* SAVING & LOADING */
|
/* SAVING & LOADING */
|
||||||
|
|
159
common/buildcraft/transport/pipes/PipeItemsStripes.java
Executable file
159
common/buildcraft/transport/pipes/PipeItemsStripes.java
Executable file
|
@ -0,0 +1,159 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) 2011-2014, SpaceToad and the BuildCraft Team
|
||||||
|
* http://www.mod-buildcraft.com
|
||||||
|
*
|
||||||
|
* BuildCraft is distributed under the terms of the Minecraft Mod Public
|
||||||
|
* License 1.0, or MMPL. Please check the contents of the license located in
|
||||||
|
* http://www.mod-buildcraft.com/MMPL-1.0.txt
|
||||||
|
*/
|
||||||
|
package buildcraft.transport.pipes;
|
||||||
|
|
||||||
|
import net.minecraft.item.Item;
|
||||||
|
import net.minecraft.tileentity.TileEntity;
|
||||||
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
|
import buildcraft.BuildCraftTransport;
|
||||||
|
import buildcraft.api.core.IIconProvider;
|
||||||
|
import buildcraft.api.core.Position;
|
||||||
|
import buildcraft.core.proxy.CoreProxy;
|
||||||
|
import buildcraft.transport.Pipe;
|
||||||
|
import buildcraft.transport.PipeIconProvider;
|
||||||
|
import buildcraft.transport.PipeTransportItems;
|
||||||
|
import buildcraft.transport.TileGenericPipe;
|
||||||
|
import buildcraft.transport.pipes.events.PipeEventItem;
|
||||||
|
|
||||||
|
public class PipeItemsStripes extends Pipe {
|
||||||
|
|
||||||
|
public PipeItemsStripes(Item item) {
|
||||||
|
super(new PipeTransportItems(), item);
|
||||||
|
|
||||||
|
//((PipeTransportItems) transport).travelHook = this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*@Override
|
||||||
|
public void doWork() {
|
||||||
|
if (powerProvider.useEnergy(1, 1, true) == 1) {
|
||||||
|
ForgeDirection o = getOpenOrientation();
|
||||||
|
|
||||||
|
if (o != ForgeDirection.Unknown) {
|
||||||
|
Position p = new Position(xCoord, yCoord, zCoord, o);
|
||||||
|
p.moveForwards(1.0);
|
||||||
|
|
||||||
|
ArrayList<ItemStack> stacks = BuildCraftBlockUtil
|
||||||
|
.getItemStackFromBlock(worldObj, (int) p.x, (int) p.y,
|
||||||
|
(int) p.z);
|
||||||
|
|
||||||
|
if (stacks != null) {
|
||||||
|
for (ItemStack s : stacks) {
|
||||||
|
if (s != null) {
|
||||||
|
IPipedItem newItem = new EntityPassiveItem(
|
||||||
|
worldObj, xCoord + 0.5, yCoord
|
||||||
|
+ Utils.getPipeFloorOf(s),
|
||||||
|
zCoord + 0.5, s);
|
||||||
|
|
||||||
|
this.container.entityEntering(newItem, o.reverse());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
worldObj.setBlock((int) p.x, (int) p.y, (int) p.z, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}*/
|
||||||
|
|
||||||
|
public void eventHandler(PipeEventItem.DropItem event) {
|
||||||
|
System.out.println ("EVENT " + event.direction);
|
||||||
|
|
||||||
|
Position p = new Position(container.xCoord, container.yCoord,
|
||||||
|
container.zCoord, ForgeDirection.UP);
|
||||||
|
Position from = new Position (p);
|
||||||
|
p.moveForwards(1.0);
|
||||||
|
|
||||||
|
//if (getWorld().getBlock((int) p.x, (int) p.y, (int) p.z) == Blocks.air) {
|
||||||
|
System.out.println ("TRY PLACE");
|
||||||
|
|
||||||
|
event.entity.getEntityItem().tryPlaceItemIntoWorld(
|
||||||
|
CoreProxy.proxy.getBuildCraftPlayer(getWorld()),
|
||||||
|
getWorld(),
|
||||||
|
(int) p.x, (int) p.y - 1, (int) p.z, 1, 0.0f, 0.0f, 0.0f);
|
||||||
|
//}
|
||||||
|
|
||||||
|
/*if (convertPipe(pipe, data)) {
|
||||||
|
BuildCraftTransport.pipeItemsStipes.onItemUse(new ItemStack(
|
||||||
|
BuildCraftTransport.pipeItemsStipes), CoreProxy
|
||||||
|
.getBuildCraftPlayer(worldObj), worldObj, (int) p.x,
|
||||||
|
(int) p.y - 1, (int) p.z, 1);
|
||||||
|
} else else {
|
||||||
|
data.item
|
||||||
|
.getItemStack()
|
||||||
|
.getItem()
|
||||||
|
.tryPlaceIntoWorld(data.item.getItemStack(),
|
||||||
|
CoreProxy.getBuildCraftPlayer(worldObj), worldObj,
|
||||||
|
(int) p.x, (int) p.y, (int) p.z, 1, 0.0f, 0.0f,
|
||||||
|
0.0f);
|
||||||
|
}*/
|
||||||
|
}
|
||||||
|
|
||||||
|
/*@Override
|
||||||
|
public void centerReached(PipeTransportItems pipe, EntityData data) {
|
||||||
|
convertPipe(pipe, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
public boolean convertPipe(PipeTransportItems pipe, EntityData data) {
|
||||||
|
|
||||||
|
if (data.item.getItemStack().getItem() instanceof ItemPipe) {
|
||||||
|
if (!(data.item.getItemStack().itemID == BuildCraftTransport.pipeItemsStipes.shiftedIndex)) {
|
||||||
|
|
||||||
|
Pipe newPipe = BlockGenericPipe.createPipe(data.item
|
||||||
|
.getItemStack().itemID);
|
||||||
|
newPipe.setTile(this.container);
|
||||||
|
this.container.pipe = newPipe;
|
||||||
|
((PipeTransportItems) newPipe.transport).travelingEntities = (TreeMap<Integer, EntityData>) pipe.travelingEntities
|
||||||
|
.clone();
|
||||||
|
|
||||||
|
data.item.getItemStack().stackSize--;
|
||||||
|
|
||||||
|
if (data.item.getItemStack().stackSize <= 0) {
|
||||||
|
((PipeTransportItems) newPipe.transport).travelingEntities
|
||||||
|
.remove(data.item.getEntityId());
|
||||||
|
}
|
||||||
|
|
||||||
|
pipe.scheduleRemoval(data.item);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void endReached(PipeTransportItems pipe, EntityData data,
|
||||||
|
TileEntity tile) {
|
||||||
|
|
||||||
|
}*/
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public IIconProvider getIconProvider() {
|
||||||
|
return BuildCraftTransport.instance.pipeIconProvider;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getIconIndex(ForgeDirection direction) {
|
||||||
|
return PipeIconProvider.TYPE.Stripes.ordinal();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean canPipeConnect(TileEntity tile, ForgeDirection side) {
|
||||||
|
if (tile instanceof TileGenericPipe) {
|
||||||
|
TileGenericPipe tilePipe = (TileGenericPipe) tile;
|
||||||
|
|
||||||
|
if (tilePipe.pipe instanceof PipeItemsStripes) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return super.canPipeConnect(tile, side);
|
||||||
|
}
|
||||||
|
}
|
|
@ -8,11 +8,12 @@
|
||||||
*/
|
*/
|
||||||
package buildcraft.transport.pipes.events;
|
package buildcraft.transport.pipes.events;
|
||||||
|
|
||||||
import buildcraft.transport.TravelingItem;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import net.minecraft.entity.item.EntityItem;
|
import net.minecraft.entity.item.EntityItem;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
|
import buildcraft.transport.TravelingItem;
|
||||||
|
|
||||||
public abstract class PipeEventItem extends PipeEvent {
|
public abstract class PipeEventItem extends PipeEvent {
|
||||||
|
|
||||||
|
@ -52,10 +53,20 @@ public abstract class PipeEventItem extends PipeEvent {
|
||||||
public static class DropItem extends PipeEventItem {
|
public static class DropItem extends PipeEventItem {
|
||||||
|
|
||||||
public EntityItem entity;
|
public EntityItem entity;
|
||||||
|
public ForgeDirection direction = ForgeDirection.UNKNOWN;
|
||||||
|
|
||||||
public DropItem(TravelingItem item, EntityItem entity) {
|
public DropItem(TravelingItem item, EntityItem entity) {
|
||||||
super(item);
|
super(item);
|
||||||
this.entity = entity;
|
this.entity = entity;
|
||||||
|
|
||||||
|
System.out.println ("OUTPUT = " + item.output);
|
||||||
|
System.out.println ("INPUT = " + item.output);
|
||||||
|
|
||||||
|
if (item.output != ForgeDirection.UNKNOWN) {
|
||||||
|
this.direction = item.output;
|
||||||
|
} else {
|
||||||
|
this.direction = item.input.getOpposite();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue