summaryrefslogtreecommitdiffstats
path: root/src/main/java/net/minecraft/server/ContainerWorkbench.java
diff options
context:
space:
mode:
authorCeltic Minstrel <celtic.minstrel.ca@>2011-04-15 22:11:13 -0400
committerEvilSeph <evilseph@unaligned.org>2011-05-01 23:40:48 -0400
commit5a5ce79035f7ed3d77974c4eb8bc94b2ffae54e7 (patch)
tree5c01022ac2f21947669a4ef02e3213f491ce2963 /src/main/java/net/minecraft/server/ContainerWorkbench.java
parent017b15c3a62a2cf066f2ec061da0de582bc5c596 (diff)
downloadcraftbukkit-5a5ce79035f7ed3d77974c4eb8bc94b2ffae54e7.tar
craftbukkit-5a5ce79035f7ed3d77974c4eb8bc94b2ffae54e7.tar.gz
craftbukkit-5a5ce79035f7ed3d77974c4eb8bc94b2ffae54e7.tar.lz
craftbukkit-5a5ce79035f7ed3d77974c4eb8bc94b2ffae54e7.tar.xz
craftbukkit-5a5ce79035f7ed3d77974c4eb8bc94b2ffae54e7.zip
Implemented addRecipe method in CraftServer and associated recipe classes.
Diffstat (limited to 'src/main/java/net/minecraft/server/ContainerWorkbench.java')
-rw-r--r--src/main/java/net/minecraft/server/ContainerWorkbench.java71
1 files changed, 71 insertions, 0 deletions
diff --git a/src/main/java/net/minecraft/server/ContainerWorkbench.java b/src/main/java/net/minecraft/server/ContainerWorkbench.java
new file mode 100644
index 00000000..d5d51dd4
--- /dev/null
+++ b/src/main/java/net/minecraft/server/ContainerWorkbench.java
@@ -0,0 +1,71 @@
+package net.minecraft.server;
+
+// CraftBukkit
+import java.util.ArrayList;
+
+public class ContainerWorkbench extends Container {
+
+ public InventoryCrafting a = new InventoryCrafting(this, 3, 3);
+ public IInventory b = new InventoryCraftResult();
+ private World c;
+ private int h;
+ private int i;
+ private int j;
+
+ public ContainerWorkbench(InventoryPlayer inventoryplayer, World world, int i, int j, int k) {
+ this.c = world;
+ this.h = i;
+ this.i = j;
+ this.j = k;
+ this.a((Slot) (new SlotResult(inventoryplayer.d, this.a, this.b, 0, 124, 35)));
+
+ int l;
+ int i1;
+
+ for (l = 0; l < 3; ++l) {
+ for (i1 = 0; i1 < 3; ++i1) {
+ this.a(new Slot(this.a, i1 + l * 3, 30 + i1 * 18, 17 + l * 18));
+ }
+ }
+
+ for (l = 0; l < 3; ++l) {
+ for (i1 = 0; i1 < 9; ++i1) {
+ this.a(new Slot(inventoryplayer, i1 + l * 9 + 9, 8 + i1 * 18, 84 + l * 18));
+ }
+ }
+
+ for (l = 0; l < 9; ++l) {
+ this.a(new Slot(inventoryplayer, l, 8 + l * 18, 142));
+ }
+
+ this.a((IInventory) this.a);
+ }
+
+ public void a(IInventory iinventory) {
+ // CraftBukkit start
+ ItemStack craftResult = CraftingManager.a().a(this.a);
+ this.b.setItem(0, craftResult);
+ if (super.g.size() < 1) {
+ return;
+ }
+ EntityPlayer player = (EntityPlayer) super.g.get(0); // TODO: Is this _always_ correct? Seems like it.
+ player.netServerHandler.sendPacket((Packet) (new Packet103SetSlot(player.activeContainer.f, 0, craftResult)));
+ // CraftBukkit end
+ }
+
+ public void a(EntityHuman entityhuman) {
+ super.a(entityhuman);
+
+ for (int i = 0; i < 9; ++i) {
+ ItemStack itemstack = this.a.getItem(i);
+
+ if (itemstack != null) {
+ entityhuman.b(itemstack);
+ }
+ }
+ }
+
+ public boolean b(EntityHuman entityhuman) {
+ return this.c.getTypeId(this.h, this.i, this.j) != Block.WORKBENCH.id ? false : entityhuman.d((double) this.h + 0.5D, (double) this.i + 0.5D, (double) this.j + 0.5D) <= 64.0D;
+ }
+}