made progress in pipe support for blueprints

This commit is contained in:
SpaceToad 2014-03-01 09:56:29 +01:00
parent 3fba674ef8
commit ebb9857a7a
3 changed files with 66 additions and 125 deletions

View file

@ -8,22 +8,8 @@
*/ */
package buildcraft.transport; package buildcraft.transport;
import buildcraft.api.transport.PipeWire;
import buildcraft.BuildCraftTransport;
import buildcraft.api.core.IIconProvider;
import buildcraft.api.core.SafeTimeTracker;
import buildcraft.api.gates.IAction;
import buildcraft.api.gates.ITrigger;
import buildcraft.core.IDropControlInventory;
import buildcraft.core.inventory.InvUtils;
import buildcraft.core.network.TilePacketWrapper;
import buildcraft.core.utils.Utils;
import buildcraft.transport.gates.GateFactory;
import buildcraft.transport.pipes.events.PipeEvent;
import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.Map; import java.util.Map;
@ -38,6 +24,20 @@ import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.common.util.ForgeDirection; import net.minecraftforge.common.util.ForgeDirection;
import buildcraft.BuildCraftTransport;
import buildcraft.api.core.IIconProvider;
import buildcraft.api.core.SafeTimeTracker;
import buildcraft.api.gates.IAction;
import buildcraft.api.gates.ITrigger;
import buildcraft.api.transport.PipeWire;
import buildcraft.core.IDropControlInventory;
import buildcraft.core.inventory.InvUtils;
import buildcraft.core.network.TilePacketWrapper;
import buildcraft.core.utils.Utils;
import buildcraft.transport.gates.GateFactory;
import buildcraft.transport.pipes.events.PipeEvent;
import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
public abstract class Pipe<T extends PipeTransport> implements IDropControlInventory { public abstract class Pipe<T extends PipeTransport> implements IDropControlInventory {
@ -439,29 +439,39 @@ public abstract class Pipe<T extends PipeTransport> implements IDropControlInven
} }
public void onBlockRemoval() { public void onBlockRemoval() {
for (ItemStack stack : computeItemDrop()) {
dropItem(stack);
}
}
public ArrayList <ItemStack> computeItemDrop () {
ArrayList <ItemStack> result = new ArrayList <ItemStack> ();
for (PipeWire pipeWire : PipeWire.VALUES) { for (PipeWire pipeWire : PipeWire.VALUES) {
if (wireSet[pipeWire.ordinal()]) if (wireSet[pipeWire.ordinal()]) {
dropItem(pipeWire.getStack()); result.add(pipeWire.getStack());
}
} }
if (hasGate()) { if (hasGate()) {
gate.dropGate(); result.add(gate.getGateItem());
resetGate();
} }
for (ForgeDirection direction : ForgeDirection.VALID_DIRECTIONS) { for (ForgeDirection direction : ForgeDirection.VALID_DIRECTIONS) {
if (container.hasFacade(direction)) { if (container.hasFacade(direction)) {
container.dropFacade(direction); result.add (container.getFacade(direction));
} }
if (container.hasPlug(direction)) { if (container.hasPlug(direction)) {
container.removeAndDropPlug(direction); result.add (new ItemStack(BuildCraftTransport.plugItem));
} }
if (container.hasRobotStation(direction)) { if (container.hasRobotStation(direction)) {
container.removeAndDropRobotStation(direction); result.add (new ItemStack(BuildCraftTransport.robotStationItem));
} }
} }
return result;
} }
public boolean isTriggerActive(ITrigger trigger) { public boolean isTriggerActive(ITrigger trigger) {

View file

@ -660,20 +660,28 @@ public class TileGenericPipe extends TileEntity implements IPowerReceptor, IFlui
} }
public boolean hasFacade(ForgeDirection direction) { public boolean hasFacade(ForgeDirection direction) {
if (direction == null || direction == ForgeDirection.UNKNOWN) if (direction == null || direction == ForgeDirection.UNKNOWN) {
return false; return false;
if (this.getWorldObj().isRemote) } else if (this.getWorldObj().isRemote) {
return renderState.facadeMatrix.getFacadeBlock(direction) != null; return renderState.facadeMatrix.getFacadeBlock(direction) != null;
return (this.facadeBlocks[direction.ordinal()] != null); } else {
return (this.facadeBlocks[direction.ordinal()] != null);
}
} }
private void dropFacadeItem(ForgeDirection direction) { private void dropFacadeItem(ForgeDirection direction) {
InvUtils.dropItems(worldObj, ItemFacade.getStack(this.facadeBlocks[direction.ordinal()], this.facadeMeta[direction.ordinal()]), this.xCoord, this.yCoord, this.zCoord); InvUtils.dropItems(worldObj, getFacade(direction), this.xCoord, this.yCoord, this.zCoord);
}
public ItemStack getFacade (ForgeDirection direction) {
return ItemFacade.getStack(this.facadeBlocks[direction.ordinal()], this.facadeMeta[direction.ordinal()]);
} }
public boolean dropFacade(ForgeDirection direction) { public boolean dropFacade(ForgeDirection direction) {
if (!hasFacade(direction)) if (!hasFacade(direction)) {
return false; return false;
}
if (!worldObj.isRemote) { if (!worldObj.isRemote) {
dropFacadeItem(direction); dropFacadeItem(direction);
this.facadeBlocks[direction.ordinal()] = null; this.facadeBlocks[direction.ordinal()] = null;
@ -681,6 +689,7 @@ public class TileGenericPipe extends TileEntity implements IPowerReceptor, IFlui
worldObj.notifyBlockChange(this.xCoord, this.yCoord, this.zCoord, getBlock()); worldObj.notifyBlockChange(this.xCoord, this.yCoord, this.zCoord, getBlock());
scheduleRenderUpdate(); scheduleRenderUpdate();
} }
return true; return true;
} }

View file

@ -8,16 +8,18 @@
*/ */
package buildcraft.transport.blueprints; package buildcraft.transport.blueprints;
import java.util.ArrayList;
import java.util.LinkedList; import java.util.LinkedList;
import net.minecraft.block.Block; import net.minecraft.block.Block;
import net.minecraft.item.Item; import net.minecraft.item.Item;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound; import net.minecraft.nbt.NBTTagCompound;
import buildcraft.BuildCraftTransport; import net.minecraft.nbt.NBTTagList;
import buildcraft.api.blueprints.BptBlock; import buildcraft.api.blueprints.BptBlock;
import buildcraft.api.blueprints.BptSlotInfo; import buildcraft.api.blueprints.BptSlotInfo;
import buildcraft.api.blueprints.IBptContext; import buildcraft.api.blueprints.IBptContext;
import buildcraft.core.utils.Utils;
import buildcraft.transport.BlockGenericPipe; import buildcraft.transport.BlockGenericPipe;
import buildcraft.transport.Pipe; import buildcraft.transport.Pipe;
@ -33,38 +35,12 @@ public class BptBlockPipe extends BptBlock {
requirements.add(new ItemStack(pipeItem)); requirements.add(new ItemStack(pipeItem));
if (slot.cpt.hasKey("wire0")) { NBTTagList nbtDrops = slot.cpt.getTagList("drops", Utils.NBTTag_Types.NBTTagCompound.ordinal());
requirements.add(new ItemStack(BuildCraftTransport.pipeWire, 1, 0));
}
if (slot.cpt.hasKey("wire1")) { for (int i = 0; i < nbtDrops.tagCount(); ++i) {
requirements.add(new ItemStack(BuildCraftTransport.pipeWire, 1, 1)); NBTTagCompound nbt = nbtDrops.getCompoundTagAt(i);
requirements.add(ItemStack.loadItemStackFromNBT(nbt));
} }
if (slot.cpt.hasKey("wire2")) {
requirements.add(new ItemStack(BuildCraftTransport.pipeWire, 1, 2));
}
if (slot.cpt.hasKey("wire3")) {
requirements.add(new ItemStack(BuildCraftTransport.pipeWire, 1, 3));
}
if (slot.cpt.hasKey("gate")) {
requirements.add (ItemStack.loadItemStackFromNBT(slot.cpt.getCompoundTag("gate")));
}
/*if (slot.cpt.hasKey("gate")) {
int gateId = slot.cpt.getInteger("gate");
if (slot.cpt.hasKey("hasPulser") && slot.cpt.getBoolean("hasPulser")) {
requirements.add(new ItemStack(BuildCraftTransport.pipeGateAutarchic, 1, gateId - 1));
} else {
requirements.add(new ItemStack(BuildCraftTransport.pipeGate, 1, gateId - 1));
}
}
if (BuildCraftCore.itemBptProps[pipeId] != null) {
BuildCraftCore.itemBptProps[pipeId].addRequirements(slot, requirements);
}*/
} }
@Override @Override
@ -90,7 +66,6 @@ public class BptBlockPipe extends BptBlock {
@Override @Override
public void buildBlock(BptSlotInfo slot, IBptContext context) { public void buildBlock(BptSlotInfo slot, IBptContext context) {
// TODO: use directly an NBT built from the pipe here.
int pipeId = slot.cpt.getInteger("pipeId"); int pipeId = slot.cpt.getInteger("pipeId");
Pipe pipe = BlockGenericPipe.createPipe(context.getMappingRegistry() Pipe pipe = BlockGenericPipe.createPipe(context.getMappingRegistry()
@ -104,36 +79,6 @@ public class BptBlockPipe extends BptBlock {
/*if (slot.cpt.hasKey("gate")) {
int gateId = slot.cpt.getInteger("gate");
GateVanilla newGate;
if (slot.cpt.hasKey("hasPulser") && slot.cpt.getBoolean("hasPulser")) {
newGate = new GateVanilla(pipe, new ItemStack(BuildCraftTransport.pipeGateAutarchic, 1, gateId - 1));
} else {
newGate = new GateVanilla(pipe, new ItemStack(BuildCraftTransport.pipeGate, 1, gateId - 1));
}
pipe.gate = newGate;
for (int i = 0; i < 8; ++i) {
if (slot.cpt.hasKey("trigger" + i)) {
pipe.gate.actions[i] = ActionManager.triggers[slot.cpt.getInteger("trigger" + i)];
}
if (slot.cpt.hasKey("triggerParameter" + i)) {
ItemStack s = ItemStack.loadItemStackFromNBT((NBTTagCompound) slot.cpt.getTag("triggerParameter" + i));
if (s != null) {
pipe.triggerParameters[i] = new TriggerParameter();
pipe.triggerParameters[i].set(s);
}
}
if (slot.cpt.hasKey("action" + i)) {
pipe.activatedActions[i] = ActionManager.actions[slot.cpt.getInteger("action" + i)];
}
}
}*/
BlockGenericPipe.placePipe(pipe, context.world(), slot.x, slot.y, BlockGenericPipe.placePipe(pipe, context.world(), slot.x, slot.y,
slot.z, slot.block, slot.meta); slot.z, slot.block, slot.meta);
@ -151,47 +96,24 @@ public class BptBlockPipe extends BptBlock {
bptSlot.cpt.setInteger("pipeId", context.getMappingRegistry() bptSlot.cpt.setInteger("pipeId", context.getMappingRegistry()
.getIdForItem(pipe.item)); .getIdForItem(pipe.item));
for (int i = 0; i < pipe.wireSet.length; ++i) { NBTTagList nbtDrops = new NBTTagList();
if (pipe.wireSet[i]) {
bptSlot.cpt.setInteger("wire" + i, 1); ArrayList<ItemStack> drops = pipe.computeItemDrop ();
}
for (ItemStack s : drops) {
NBTTagCompound nbtStack = new NBTTagCompound();
s.writeToNBT(nbtStack);
nbtDrops.appendTag(nbtStack);
} }
if (pipe.hasGate()) { bptSlot.cpt.setTag("drops", nbtDrops);
NBTTagCompound gateNBT = new NBTTagCompound();
pipe.gate.getGateItem().writeToNBT(gateNBT);
bptSlot.cpt.setTag("gate", gateNBT);
}
NBTTagCompound worldNbt = new NBTTagCompound();
pipe.writeToNBT(worldNbt);
// / TODO: Does not save/load custom gates bptSlot.cpt.setTag("worldNBT", worldNbt);
/*if (pipe.hasGate()) {
bptSlot.cpt.setInteger("gate", pipe.gate.kind.ordinal());
if (pipe.gate instanceof GateVanilla) {
bptSlot.cpt.setBoolean("hasPulser", ((GateVanilla) pipe.gate).hasPulser());
}
for (int i = 0; i < 8; ++i) { // TODO: store the pipe nbt on disk as well...
if (pipe.activatedTriggers[i] != null) {
bptSlot.cpt.setInteger("trigger" + i, pipe.activatedTriggers[i].getId());
}
if (pipe.triggerParameters[i] != null) {
NBTTagCompound subCpt = new NBTTagCompound();
pipe.triggerParameters[i].getItemStack().writeToNBT(subCpt);
bptSlot.cpt.setTag("triggerParameter" + i, subCpt);
}
if (pipe.activatedActions[i] != null) {
bptSlot.cpt.setInteger("action" + i, pipe.activatedActions[i].getId());
}
}
}
if (BuildCraftCore.itemBptProps[pipe.itemID] != null) {
BuildCraftCore.itemBptProps[pipe.itemID].initializeFromWorld(bptSlot, context, x, y, z);
}*/
} }
} }