Re-introduction of the builder block
Added back the builder block to the world, with fixes of initial obvious errors. TileArchitect is now passing its name through RPCs.
This commit is contained in:
parent
9dab76fc71
commit
08d01c0394
6 changed files with 30 additions and 13 deletions
|
@ -10,12 +10,15 @@ package buildcraft.builders;
|
||||||
import buildcraft.BuildCraftBuilders;
|
import buildcraft.BuildCraftBuilders;
|
||||||
import buildcraft.api.core.Position;
|
import buildcraft.api.core.Position;
|
||||||
import buildcraft.api.tools.IToolWrench;
|
import buildcraft.api.tools.IToolWrench;
|
||||||
|
import buildcraft.core.CreativeTabBuildCraft;
|
||||||
import buildcraft.core.GuiIds;
|
import buildcraft.core.GuiIds;
|
||||||
import buildcraft.core.proxy.CoreProxy;
|
import buildcraft.core.proxy.CoreProxy;
|
||||||
import buildcraft.core.utils.Utils;
|
import buildcraft.core.utils.Utils;
|
||||||
import cpw.mods.fml.relauncher.Side;
|
import cpw.mods.fml.relauncher.Side;
|
||||||
import cpw.mods.fml.relauncher.SideOnly;
|
import cpw.mods.fml.relauncher.SideOnly;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import net.minecraft.block.BlockContainer;
|
import net.minecraft.block.BlockContainer;
|
||||||
import net.minecraft.block.material.Material;
|
import net.minecraft.block.material.Material;
|
||||||
import net.minecraft.client.renderer.texture.IconRegister;
|
import net.minecraft.client.renderer.texture.IconRegister;
|
||||||
|
@ -37,7 +40,7 @@ public class BlockBuilder extends BlockContainer {
|
||||||
public BlockBuilder(int i) {
|
public BlockBuilder(int i) {
|
||||||
super(i, Material.iron);
|
super(i, Material.iron);
|
||||||
setHardness(5F);
|
setHardness(5F);
|
||||||
setCreativeTab(null);
|
setCreativeTab(CreativeTabBuildCraft.MACHINES.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -41,6 +41,10 @@ public abstract class ItemBlueprint extends ItemBuildCraft {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Blueprint getBlueprint(ItemStack stack) {
|
public static Blueprint getBlueprint(ItemStack stack) {
|
||||||
|
if (stack == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
NBTTagCompound nbt = NBTUtils.getItemData(stack);
|
NBTTagCompound nbt = NBTUtils.getItemData(stack);
|
||||||
byte[] idRaw = nbt.getByteArray("blueprint");
|
byte[] idRaw = nbt.getByteArray("blueprint");
|
||||||
BlueprintId id = BlueprintId.fromRawId(idRaw);
|
BlueprintId id = BlueprintId.fromRawId(idRaw);
|
||||||
|
|
|
@ -16,9 +16,13 @@ import buildcraft.core.Box;
|
||||||
import buildcraft.core.TileBuildCraft;
|
import buildcraft.core.TileBuildCraft;
|
||||||
import buildcraft.core.network.PacketUpdate;
|
import buildcraft.core.network.PacketUpdate;
|
||||||
import buildcraft.core.network.NetworkData;
|
import buildcraft.core.network.NetworkData;
|
||||||
|
import buildcraft.core.network.RPC;
|
||||||
|
import buildcraft.core.network.RPCSide;
|
||||||
import buildcraft.core.proxy.CoreProxy;
|
import buildcraft.core.proxy.CoreProxy;
|
||||||
import buildcraft.core.utils.Utils;
|
import buildcraft.core.utils.Utils;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.inventory.IInventory;
|
import net.minecraft.inventory.IInventory;
|
||||||
|
@ -34,8 +38,9 @@ public class TileArchitect extends TileBuildCraft implements IInventory {
|
||||||
private ItemStack items[] = new ItemStack[2];
|
private ItemStack items[] = new ItemStack[2];
|
||||||
private boolean isComputing = false;
|
private boolean isComputing = false;
|
||||||
public int computingTime = 0;
|
public int computingTime = 0;
|
||||||
public @NetworkData
|
|
||||||
String name = "";
|
@NetworkData
|
||||||
|
public String name = "";
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateEntity() {
|
public void updateEntity() {
|
||||||
|
@ -139,6 +144,7 @@ public class TileArchitect extends TileBuildCraft implements IInventory {
|
||||||
return blueprint;
|
return blueprint;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@RPC
|
||||||
public void handleClientInput(char c) {
|
public void handleClientInput(char c) {
|
||||||
if (c == 8) {
|
if (c == 8) {
|
||||||
if (name.length() > 0) {
|
if (name.length() > 0) {
|
||||||
|
@ -333,4 +339,5 @@ public class TileArchitect extends TileBuildCraft implements IInventory {
|
||||||
@Override
|
@Override
|
||||||
public void closeChest() {
|
public void closeChest() {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,10 +11,10 @@ public class BlueprintMeta {
|
||||||
public BlueprintId id;
|
public BlueprintId id;
|
||||||
|
|
||||||
@NetworkData
|
@NetworkData
|
||||||
public String name;
|
public String name = "";
|
||||||
|
|
||||||
@NetworkData
|
@NetworkData
|
||||||
public String creator;
|
public String creator = "";
|
||||||
|
|
||||||
public BlueprintMeta() {
|
public BlueprintMeta() {
|
||||||
|
|
||||||
|
|
|
@ -14,6 +14,7 @@ import buildcraft.core.network.PacketIds;
|
||||||
import buildcraft.core.network.PacketPayload;
|
import buildcraft.core.network.PacketPayload;
|
||||||
import buildcraft.core.network.PacketPayloadStream;
|
import buildcraft.core.network.PacketPayloadStream;
|
||||||
import buildcraft.core.network.PacketUpdate;
|
import buildcraft.core.network.PacketUpdate;
|
||||||
|
import buildcraft.core.network.RPCHandler;
|
||||||
import buildcraft.core.proxy.CoreProxy;
|
import buildcraft.core.proxy.CoreProxy;
|
||||||
import buildcraft.core.utils.StringUtils;
|
import buildcraft.core.utils.StringUtils;
|
||||||
|
|
||||||
|
@ -82,19 +83,15 @@ public class GuiTemplate extends GuiBuildCraft {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void keyTyped(char c, int i) {
|
protected void keyTyped(char c, int i) {
|
||||||
// FIXME: Not much point to port this to stream payload at this stage,
|
if (i != 1 && editMode) {
|
||||||
// should use a RPC instead.
|
|
||||||
/*if (i != 1 && editMode) {
|
|
||||||
if (c == 13) {
|
if (c == 13) {
|
||||||
editMode = false;
|
editMode = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
PacketPayloadStream payload = new PacketPayloadStream();
|
|
||||||
payload.intPayload = new int[]{c};
|
RPCHandler.rpcServer(template, "handleClientInput", c);
|
||||||
PacketUpdate packet = new PacketUpdate(PacketIds.ARCHITECT_NAME, template.xCoord, template.yCoord, template.zCoord, payload);
|
|
||||||
CoreProxy.proxy.sendToServer(packet.getPacket());
|
|
||||||
} else {
|
} else {
|
||||||
super.keyTyped(c, i);
|
super.keyTyped(c, i);
|
||||||
}*/
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -73,6 +73,8 @@ public class RPCHandler {
|
||||||
for (int j = 0; j < mapping.parameters.length; ++j) {
|
for (int j = 0; j < mapping.parameters.length; ++j) {
|
||||||
if (mapping.parameters [j].equals(int.class)) {
|
if (mapping.parameters [j].equals(int.class)) {
|
||||||
// accepted
|
// accepted
|
||||||
|
} else if (mapping.parameters [j].equals(char.class)) {
|
||||||
|
// accepted
|
||||||
} else if (mapping.parameters [j].equals(String.class)) {
|
} else if (mapping.parameters [j].equals(String.class)) {
|
||||||
// accepted
|
// accepted
|
||||||
} else if (mapping.parameters [j].equals(RPCMessageInfo.class)) {
|
} else if (mapping.parameters [j].equals(RPCMessageInfo.class)) {
|
||||||
|
@ -156,6 +158,8 @@ public class RPCHandler {
|
||||||
for (int i = 0; i < actuals.length; ++i) {
|
for (int i = 0; i < actuals.length; ++i) {
|
||||||
if (formals [i].equals(int.class)) {
|
if (formals [i].equals(int.class)) {
|
||||||
data.writeInt((Integer) actuals [i]);
|
data.writeInt((Integer) actuals [i]);
|
||||||
|
} else if (formals [i].equals(char.class)) {
|
||||||
|
data.writeChar((Character) actuals [i]);
|
||||||
} else if (formals [i].equals(String.class)) {
|
} else if (formals [i].equals(String.class)) {
|
||||||
data.writeUTF((String) actuals [i]);
|
data.writeUTF((String) actuals [i]);
|
||||||
} else {
|
} else {
|
||||||
|
@ -191,6 +195,8 @@ public class RPCHandler {
|
||||||
for (int i = 0; i < expectedParameters; ++i) {
|
for (int i = 0; i < expectedParameters; ++i) {
|
||||||
if (formals [i].equals(int.class)) {
|
if (formals [i].equals(int.class)) {
|
||||||
actuals [i] = data.readInt();
|
actuals [i] = data.readInt();
|
||||||
|
} else if (formals [i].equals(char.class)) {
|
||||||
|
actuals [i] = data.readChar();
|
||||||
} else if (formals [i].equals(String.class)) {
|
} else if (formals [i].equals(String.class)) {
|
||||||
actuals [i] = data.readUTF();
|
actuals [i] = data.readUTF();
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue