Introduced a layer specific for tile schematic, further optimizing for #1484
This commit is contained in:
parent
add526d8f9
commit
b775c045fc
16 changed files with 134 additions and 74 deletions
|
@ -12,6 +12,7 @@ import java.lang.reflect.InvocationTargetException;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
|
import net.minecraft.block.BlockContainer;
|
||||||
import net.minecraft.init.Blocks;
|
import net.minecraft.init.Blocks;
|
||||||
|
|
||||||
public class BlueprintManager {
|
public class BlueprintManager {
|
||||||
|
@ -38,8 +39,12 @@ public class BlueprintManager {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!schematicClasses.containsKey(block)) {
|
if (!schematicClasses.containsKey(block)) {
|
||||||
|
if (block instanceof BlockContainer) {
|
||||||
|
registerSchematicClass(block, SchematicTile.class);
|
||||||
|
} else {
|
||||||
registerSchematicClass(block, Schematic.class);
|
registerSchematicClass(block, Schematic.class);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
SchematicConstructor c = schematicClasses.get(block);
|
SchematicConstructor c = schematicClasses.get(block);
|
||||||
|
|
|
@ -12,13 +12,10 @@ 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.block.BlockContainer;
|
|
||||||
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.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.nbt.NBTTagList;
|
import net.minecraft.nbt.NBTTagList;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
|
||||||
import buildcraft.core.utils.Utils;
|
import buildcraft.core.utils.Utils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -56,14 +53,6 @@ public class Schematic {
|
||||||
*/
|
*/
|
||||||
public ArrayList<ItemStack> storedRequirements = new ArrayList<ItemStack>();
|
public ArrayList<ItemStack> storedRequirements = new ArrayList<ItemStack>();
|
||||||
|
|
||||||
/**
|
|
||||||
* This tree contains additional data to be stored in the blueprint. By
|
|
||||||
* default, it will be initialized from Schematic.readFromWord with
|
|
||||||
* the standard readNBT function of the corresponding tile (if any) and will
|
|
||||||
* be loaded from BptBlock.buildBlock using the standard writeNBT function.
|
|
||||||
*/
|
|
||||||
public NBTTagCompound cpt = new NBTTagCompound();
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public Schematic clone() {
|
public Schematic clone() {
|
||||||
|
@ -71,7 +60,6 @@ public class Schematic {
|
||||||
|
|
||||||
obj.block = block;
|
obj.block = block;
|
||||||
obj.meta = meta;
|
obj.meta = meta;
|
||||||
obj.cpt = (NBTTagCompound) cpt.copy();
|
|
||||||
obj.storedRequirements = (ArrayList<ItemStack>) storedRequirements.clone();
|
obj.storedRequirements = (ArrayList<ItemStack>) storedRequirements.clone();
|
||||||
|
|
||||||
return obj;
|
return obj;
|
||||||
|
@ -174,27 +162,6 @@ public class Schematic {
|
||||||
// Meta needs to be specified twice, depending on the block behavior
|
// Meta needs to be specified twice, depending on the block behavior
|
||||||
context.world().setBlock(x, y, z, block, meta, 3);
|
context.world().setBlock(x, y, z, block, meta, 3);
|
||||||
context.world().setBlockMetadataWithNotify(x, y, z, meta, 3);
|
context.world().setBlockMetadataWithNotify(x, y, z, meta, 3);
|
||||||
|
|
||||||
if (block instanceof BlockContainer) {
|
|
||||||
TileEntity tile = context.world().getTileEntity(x, y, z);
|
|
||||||
|
|
||||||
cpt.setInteger("x", x);
|
|
||||||
cpt.setInteger("y", y);
|
|
||||||
cpt.setInteger("z", z);
|
|
||||||
|
|
||||||
if (tile != null) {
|
|
||||||
tile.readFromNBT(cpt);
|
|
||||||
}
|
|
||||||
|
|
||||||
// By default, clear the inventory to avoid possible dupe bugs
|
|
||||||
if (tile instanceof IInventory) {
|
|
||||||
IInventory inv = (IInventory) tile;
|
|
||||||
|
|
||||||
for (int i = 0; i < inv.getSizeInventory(); ++i) {
|
|
||||||
inv.setInventorySlotContents(i, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -215,14 +182,6 @@ public class Schematic {
|
||||||
* save / load the block.
|
* save / load the block.
|
||||||
*/
|
*/
|
||||||
public void readFromWorld(IBuilderContext context, int x, int y, int z) {
|
public void readFromWorld(IBuilderContext context, int x, int y, int z) {
|
||||||
if (block instanceof BlockContainer) {
|
|
||||||
TileEntity tile = context.world().getTileEntity(x, y, z);
|
|
||||||
|
|
||||||
if (tile != null) {
|
|
||||||
tile.writeToNBT(cpt);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (block != null) {
|
if (block != null) {
|
||||||
ArrayList<ItemStack> req = block.getDrops(context.world(), x,
|
ArrayList<ItemStack> req = block.getDrops(context.world(), x,
|
||||||
y, z, context.world().getBlockMetadata(x, y, z), 0);
|
y, z, context.world().getBlockMetadata(x, y, z), 0);
|
||||||
|
@ -245,7 +204,6 @@ public class Schematic {
|
||||||
public void writeToNBT(NBTTagCompound nbt, MappingRegistry registry) {
|
public void writeToNBT(NBTTagCompound nbt, MappingRegistry registry) {
|
||||||
nbt.setInteger("blockId", registry.getIdForBlock(block));
|
nbt.setInteger("blockId", registry.getIdForBlock(block));
|
||||||
nbt.setInteger("blockMeta", meta);
|
nbt.setInteger("blockMeta", meta);
|
||||||
nbt.setTag("blockCpt", cpt);
|
|
||||||
|
|
||||||
NBTTagList rq = new NBTTagList();
|
NBTTagList rq = new NBTTagList();
|
||||||
|
|
||||||
|
@ -263,7 +221,6 @@ public class Schematic {
|
||||||
public void readFromNBT(NBTTagCompound nbt, MappingRegistry registry) {
|
public void readFromNBT(NBTTagCompound nbt, MappingRegistry registry) {
|
||||||
block = registry.getBlockForId(nbt.getInteger("blockId"));
|
block = registry.getBlockForId(nbt.getInteger("blockId"));
|
||||||
meta = nbt.getInteger("blockMeta");
|
meta = nbt.getInteger("blockMeta");
|
||||||
cpt = nbt.getCompoundTag("blockCpt");
|
|
||||||
|
|
||||||
NBTTagList rq = nbt.getTagList("rq", Utils.NBTTag_Types.NBTTagList.ordinal());
|
NBTTagList rq = nbt.getTagList("rq", Utils.NBTTag_Types.NBTTagList.ordinal());
|
||||||
|
|
||||||
|
|
98
common/buildcraft/api/blueprints/SchematicTile.java
Executable file
98
common/buildcraft/api/blueprints/SchematicTile.java
Executable file
|
@ -0,0 +1,98 @@
|
||||||
|
/**
|
||||||
|
* 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.api.blueprints;
|
||||||
|
|
||||||
|
import net.minecraft.block.BlockContainer;
|
||||||
|
import net.minecraft.inventory.IInventory;
|
||||||
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
|
import net.minecraft.tileentity.TileEntity;
|
||||||
|
|
||||||
|
public class SchematicTile extends Schematic {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This tree contains additional data to be stored in the blueprint. By
|
||||||
|
* default, it will be initialized from Schematic.readFromWord with
|
||||||
|
* the standard readNBT function of the corresponding tile (if any) and will
|
||||||
|
* be loaded from BptBlock.buildBlock using the standard writeNBT function.
|
||||||
|
*/
|
||||||
|
public NBTTagCompound cpt = new NBTTagCompound();
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
@Override
|
||||||
|
public Schematic clone() {
|
||||||
|
SchematicTile s = (SchematicTile) super.clone();
|
||||||
|
|
||||||
|
s.cpt = (NBTTagCompound) cpt.copy();
|
||||||
|
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Places the block in the world, at the location specified in the slot.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void writeToWorld(IBuilderContext context, int x, int y, int z) {
|
||||||
|
super.writeToWorld(context, x, y, z);
|
||||||
|
|
||||||
|
if (block instanceof BlockContainer) {
|
||||||
|
TileEntity tile = context.world().getTileEntity(x, y, z);
|
||||||
|
|
||||||
|
cpt.setInteger("x", x);
|
||||||
|
cpt.setInteger("y", y);
|
||||||
|
cpt.setInteger("z", z);
|
||||||
|
|
||||||
|
if (tile != null) {
|
||||||
|
tile.readFromNBT(cpt);
|
||||||
|
}
|
||||||
|
|
||||||
|
// By default, clear the inventory to avoid possible dupe bugs
|
||||||
|
if (tile instanceof IInventory) {
|
||||||
|
IInventory inv = (IInventory) tile;
|
||||||
|
|
||||||
|
for (int i = 0; i < inv.getSizeInventory(); ++i) {
|
||||||
|
inv.setInventorySlotContents(i, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initializes a slot from the blueprint according to an objet placed on {x,
|
||||||
|
* y, z} on the world. This typically means adding entries in slot.cpt. Note
|
||||||
|
* that "id" and "meta" will be set automatically, corresponding to the
|
||||||
|
* block id and meta.
|
||||||
|
*
|
||||||
|
* By default, if the block is a BlockContainer, tile information will be to
|
||||||
|
* save / load the block.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void readFromWorld(IBuilderContext context, int x, int y, int z) {
|
||||||
|
super.readFromWorld(context, x, y, z);
|
||||||
|
|
||||||
|
if (block instanceof BlockContainer) {
|
||||||
|
TileEntity tile = context.world().getTileEntity(x, y, z);
|
||||||
|
|
||||||
|
if (tile != null) {
|
||||||
|
tile.writeToNBT(cpt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void writeToNBT(NBTTagCompound nbt, MappingRegistry registry) {
|
||||||
|
super.writeToNBT(nbt, registry);
|
||||||
|
|
||||||
|
nbt.setTag("blockCpt", cpt);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void readFromNBT(NBTTagCompound nbt, MappingRegistry registry) {
|
||||||
|
cpt = nbt.getCompoundTag("blockCpt");
|
||||||
|
}
|
||||||
|
}
|
|
@ -17,7 +17,7 @@ import net.minecraft.nbt.NBTTagList;
|
||||||
|
|
||||||
public class SchematicUtils {
|
public class SchematicUtils {
|
||||||
|
|
||||||
public static void requestInventoryContents(Schematic slot, IBuilderContext context, LinkedList<ItemStack> requirements) {
|
public static void requestInventoryContents(SchematicTile slot, IBuilderContext context, LinkedList<ItemStack> requirements) {
|
||||||
ItemStack[] stacks = getItemStacks(slot, context);
|
ItemStack[] stacks = getItemStacks(slot, context);
|
||||||
|
|
||||||
for (ItemStack stack : stacks) {
|
for (ItemStack stack : stacks) {
|
||||||
|
@ -27,7 +27,7 @@ public class SchematicUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void initializeInventoryContents(Schematic slot, IBuilderContext context, IInventory inventory) {
|
public static void initializeInventoryContents(SchematicTile slot, IBuilderContext context, IInventory inventory) {
|
||||||
ItemStack[] stacks = new ItemStack[inventory.getSizeInventory()];
|
ItemStack[] stacks = new ItemStack[inventory.getSizeInventory()];
|
||||||
|
|
||||||
for (int i = 0; i < inventory.getSizeInventory(); ++i) {
|
for (int i = 0; i < inventory.getSizeInventory(); ++i) {
|
||||||
|
@ -37,7 +37,7 @@ public class SchematicUtils {
|
||||||
setItemStacks(slot, context, stacks);
|
setItemStacks(slot, context, stacks);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void buildInventoryContents(Schematic slot, IBuilderContext context, IInventory inventory) {
|
public static void buildInventoryContents(SchematicTile slot, IBuilderContext context, IInventory inventory) {
|
||||||
ItemStack[] stacks = getItemStacks(slot, context);
|
ItemStack[] stacks = getItemStacks(slot, context);
|
||||||
|
|
||||||
for (int i = 0; i < stacks.length; ++i) {
|
for (int i = 0; i < stacks.length; ++i) {
|
||||||
|
@ -45,7 +45,7 @@ public class SchematicUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ItemStack[] getItemStacks(Schematic slot, IBuilderContext context) {
|
public static ItemStack[] getItemStacks(SchematicTile slot, IBuilderContext context) {
|
||||||
NBTTagList list = (NBTTagList) slot.cpt.getTag("inv");
|
NBTTagList list = (NBTTagList) slot.cpt.getTag("inv");
|
||||||
|
|
||||||
if (list == null) {
|
if (list == null) {
|
||||||
|
@ -65,7 +65,7 @@ public class SchematicUtils {
|
||||||
return stacks;
|
return stacks;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void setItemStacks(Schematic slot, IBuilderContext context, ItemStack[] stacks) {
|
public static void setItemStacks(SchematicTile slot, IBuilderContext context, ItemStack[] stacks) {
|
||||||
NBTTagList nbttaglist = new NBTTagList();
|
NBTTagList nbttaglist = new NBTTagList();
|
||||||
|
|
||||||
for (ItemStack stack : stacks) {
|
for (ItemStack stack : stacks) {
|
||||||
|
|
|
@ -10,9 +10,9 @@ package buildcraft.api.schematics;
|
||||||
|
|
||||||
import net.minecraft.inventory.IInventory;
|
import net.minecraft.inventory.IInventory;
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
|
|
||||||
public class SchematicInventory extends Schematic {
|
public class SchematicInventory extends SchematicTile {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void writeToWorld(IBuilderContext context, int x, int y, int z) {
|
public void writeToWorld(IBuilderContext context, int x, int y, int z) {
|
||||||
|
|
|
@ -12,9 +12,9 @@ import java.util.LinkedList;
|
||||||
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
|
|
||||||
public class SchematicRotateMeta extends Schematic {
|
public class SchematicRotateMeta extends SchematicTile {
|
||||||
|
|
||||||
int[] rot;
|
int[] rot;
|
||||||
boolean rotateForward;
|
boolean rotateForward;
|
||||||
|
|
|
@ -13,10 +13,10 @@ import java.util.LinkedList;
|
||||||
import net.minecraft.init.Items;
|
import net.minecraft.init.Items;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
|
|
||||||
public class SchematicSign extends Schematic {
|
public class SchematicSign extends SchematicTile {
|
||||||
|
|
||||||
boolean isWall;
|
boolean isWall;
|
||||||
|
|
||||||
|
|
|
@ -10,9 +10,9 @@ package buildcraft.energy;
|
||||||
|
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
|
|
||||||
public class SchematicEngine extends Schematic {
|
public class SchematicEngine extends SchematicTile {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void rotateLeft(IBuilderContext context) {
|
public void rotateLeft(IBuilderContext context) {
|
||||||
|
|
|
@ -13,10 +13,10 @@ import java.util.LinkedList;
|
||||||
import net.minecraft.inventory.IInventory;
|
import net.minecraft.inventory.IInventory;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
import buildcraft.api.blueprints.SchematicUtils;
|
import buildcraft.api.blueprints.SchematicUtils;
|
||||||
|
|
||||||
public class SchematicAutoWorkbench extends Schematic {
|
public class SchematicAutoWorkbench extends SchematicTile {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void addRequirements(IBuilderContext context, LinkedList<ItemStack> requirements) {
|
public void addRequirements(IBuilderContext context, LinkedList<ItemStack> requirements) {
|
||||||
|
|
|
@ -10,9 +10,9 @@ package buildcraft.factory;
|
||||||
|
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
|
|
||||||
public class SchematicRefinery extends Schematic {
|
public class SchematicRefinery extends SchematicTile {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void rotateLeft(IBuilderContext context) {
|
public void rotateLeft(IBuilderContext context) {
|
||||||
|
|
|
@ -9,9 +9,9 @@
|
||||||
package buildcraft.factory;
|
package buildcraft.factory;
|
||||||
|
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
|
|
||||||
public class SchematicTank extends Schematic {
|
public class SchematicTank extends SchematicTile {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void readFromWorld(IBuilderContext context, int x, int y, int z) {
|
public void readFromWorld(IBuilderContext context, int x, int y, int z) {
|
||||||
|
|
|
@ -10,8 +10,8 @@ package buildcraft.transport.blueprints;
|
||||||
|
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
import buildcraft.core.inventory.SimpleInventory;
|
import buildcraft.core.inventory.SimpleInventory;
|
||||||
|
|
||||||
public class BptItemPipeFilters extends BptPipeExtension {
|
public class BptItemPipeFilters extends BptPipeExtension {
|
||||||
|
@ -22,7 +22,7 @@ public class BptItemPipeFilters extends BptPipeExtension {
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void rotateLeft(Schematic slot, IBuilderContext context) {
|
public void rotateLeft(SchematicTile slot, IBuilderContext context) {
|
||||||
SimpleInventory inv = new SimpleInventory(54, "Filters", 1);
|
SimpleInventory inv = new SimpleInventory(54, "Filters", 1);
|
||||||
SimpleInventory newInv = new SimpleInventory(54, "Filters", 1);
|
SimpleInventory newInv = new SimpleInventory(54, "Filters", 1);
|
||||||
inv.readFromNBT(slot.cpt);
|
inv.readFromNBT(slot.cpt);
|
||||||
|
|
|
@ -3,8 +3,8 @@ package buildcraft.transport.blueprints;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
|
|
||||||
public class BptPipeExtension {
|
public class BptPipeExtension {
|
||||||
|
|
||||||
|
@ -14,11 +14,11 @@ public class BptPipeExtension {
|
||||||
bptPipeExtensionRegistry.put(i, this);
|
bptPipeExtensionRegistry.put(i, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void postProcessing(Schematic slot, IBuilderContext context) {
|
public void postProcessing(SchematicTile slot, IBuilderContext context) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void rotateLeft(Schematic slot, IBuilderContext context) {
|
public void rotateLeft(SchematicTile slot, IBuilderContext context) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,8 +10,8 @@ package buildcraft.transport.blueprints;
|
||||||
|
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
|
|
||||||
public class BptPipeIron extends BptPipeExtension {
|
public class BptPipeIron extends BptPipeExtension {
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ public class BptPipeIron extends BptPipeExtension {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void rotateLeft(Schematic slot, IBuilderContext context) {
|
public void rotateLeft(SchematicTile slot, IBuilderContext context) {
|
||||||
int orientation = slot.meta & 7;
|
int orientation = slot.meta & 7;
|
||||||
int others = slot.meta - orientation;
|
int others = slot.meta - orientation;
|
||||||
|
|
||||||
|
|
|
@ -10,8 +10,8 @@ package buildcraft.transport.blueprints;
|
||||||
|
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
|
|
||||||
public class BptPipeWooden extends BptPipeExtension {
|
public class BptPipeWooden extends BptPipeExtension {
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ public class BptPipeWooden extends BptPipeExtension {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void rotateLeft(Schematic slot, IBuilderContext context) {
|
public void rotateLeft(SchematicTile slot, IBuilderContext context) {
|
||||||
int orientation = slot.meta & 7;
|
int orientation = slot.meta & 7;
|
||||||
int others = slot.meta - orientation;
|
int others = slot.meta - orientation;
|
||||||
|
|
||||||
|
|
|
@ -14,12 +14,12 @@ import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import buildcraft.api.blueprints.IBuilderContext;
|
import buildcraft.api.blueprints.IBuilderContext;
|
||||||
import buildcraft.api.blueprints.Schematic;
|
import buildcraft.api.blueprints.SchematicTile;
|
||||||
import buildcraft.transport.BlockGenericPipe;
|
import buildcraft.transport.BlockGenericPipe;
|
||||||
import buildcraft.transport.Pipe;
|
import buildcraft.transport.Pipe;
|
||||||
import buildcraft.transport.TileGenericPipe.SideProperties;
|
import buildcraft.transport.TileGenericPipe.SideProperties;
|
||||||
|
|
||||||
public class SchematicPipe extends Schematic {
|
public class SchematicPipe extends SchematicTile {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void addRequirements(IBuilderContext context, LinkedList<ItemStack> requirements) {
|
public void addRequirements(IBuilderContext context, LinkedList<ItemStack> requirements) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue