2012-02-26 05:56:31 +01:00
|
|
|
package net.minecraft.server;
|
|
|
|
|
2012-02-29 19:56:35 +01:00
|
|
|
// CraftBukkit start
|
|
|
|
import org.bukkit.craftbukkit.inventory.CraftInventory;
|
|
|
|
import org.bukkit.craftbukkit.inventory.CraftInventoryView;
|
|
|
|
// CraftBukkit end
|
|
|
|
|
2012-02-26 05:56:31 +01:00
|
|
|
public class ContainerBrewingStand extends Container {
|
|
|
|
|
2012-02-29 22:31:04 +01:00
|
|
|
private TileEntityBrewingStand brewingStand;
|
2012-02-26 05:56:31 +01:00
|
|
|
private int b = 0;
|
2012-02-29 19:56:35 +01:00
|
|
|
// CraftBukkit start
|
|
|
|
private CraftInventoryView bukkitEntity = null;
|
|
|
|
private PlayerInventory player;
|
|
|
|
// CraftBukkit end
|
2012-02-26 05:56:31 +01:00
|
|
|
|
|
|
|
public ContainerBrewingStand(PlayerInventory playerinventory, TileEntityBrewingStand tileentitybrewingstand) {
|
2012-02-29 19:56:35 +01:00
|
|
|
player = playerinventory; // CraftBukkit
|
2012-02-29 22:31:04 +01:00
|
|
|
this.brewingStand = tileentitybrewingstand;
|
|
|
|
this.a(new SlotPotionBottle(this, playerinventory.player, tileentitybrewingstand, 0, 56, 46));
|
|
|
|
this.a(new SlotPotionBottle(this, playerinventory.player, tileentitybrewingstand, 1, 79, 53));
|
|
|
|
this.a(new SlotPotionBottle(this, playerinventory.player, tileentitybrewingstand, 2, 102, 46));
|
2012-02-26 05:56:31 +01:00
|
|
|
this.a(new SlotBrewing(this, tileentitybrewingstand, 3, 79, 17));
|
|
|
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < 3; ++i) {
|
|
|
|
for (int j = 0; j < 9; ++j) {
|
|
|
|
this.a(new Slot(playerinventory, j + i * 9 + 9, 8 + j * 18, 84 + i * 18));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < 9; ++i) {
|
|
|
|
this.a(new Slot(playerinventory, i, 8 + i * 18, 142));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-02-29 22:31:04 +01:00
|
|
|
public void addSlotListener(ICrafting icrafting) {
|
|
|
|
super.addSlotListener(icrafting);
|
2012-03-01 11:49:23 +01:00
|
|
|
icrafting.setContainerData(this, 0, this.brewingStand.i());
|
2012-02-26 05:56:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public void a() {
|
|
|
|
super.a();
|
|
|
|
|
|
|
|
for (int i = 0; i < this.listeners.size(); ++i) {
|
|
|
|
ICrafting icrafting = (ICrafting) this.listeners.get(i);
|
|
|
|
|
2012-03-01 11:49:23 +01:00
|
|
|
if (this.b != this.brewingStand.i()) {
|
|
|
|
icrafting.setContainerData(this, 0, this.brewingStand.i());
|
2012-02-26 05:56:31 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-01 11:49:23 +01:00
|
|
|
this.b = this.brewingStand.i();
|
2012-02-26 05:56:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public boolean b(EntityHuman entityhuman) {
|
2012-02-29 19:56:35 +01:00
|
|
|
if (!this.checkReachable) return true; // CraftBukkit
|
2012-02-29 22:31:04 +01:00
|
|
|
return this.brewingStand.a(entityhuman);
|
2012-02-26 05:56:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public ItemStack a(int i) {
|
|
|
|
ItemStack itemstack = null;
|
|
|
|
Slot slot = (Slot) this.e.get(i);
|
|
|
|
|
|
|
|
if (slot != null && slot.c()) {
|
|
|
|
ItemStack itemstack1 = slot.getItem();
|
|
|
|
|
|
|
|
itemstack = itemstack1.cloneItemStack();
|
|
|
|
if ((i < 0 || i > 2) && i != 3) {
|
|
|
|
if (i >= 4 && i < 31) {
|
|
|
|
if (!this.a(itemstack1, 31, 40, false)) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
} else if (i >= 31 && i < 40) {
|
|
|
|
if (!this.a(itemstack1, 4, 31, false)) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
} else if (!this.a(itemstack1, 4, 40, false)) {
|
|
|
|
return null;
|
|
|
|
}
|
2012-03-01 11:49:23 +01:00
|
|
|
} else {
|
|
|
|
if (!this.a(itemstack1, 4, 40, true)) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
slot.a(itemstack1, itemstack);
|
2012-02-26 05:56:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (itemstack1.count == 0) {
|
2012-02-29 22:31:04 +01:00
|
|
|
slot.set((ItemStack) null);
|
2012-02-26 05:56:31 +01:00
|
|
|
} else {
|
|
|
|
slot.d();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (itemstack1.count == itemstack.count) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2012-03-01 11:49:23 +01:00
|
|
|
slot.c(itemstack1);
|
2012-02-26 05:56:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return itemstack;
|
|
|
|
}
|
2012-02-29 19:56:35 +01:00
|
|
|
|
|
|
|
// CraftBukkit start
|
|
|
|
public CraftInventoryView getBukkitView() {
|
|
|
|
if (bukkitEntity != null) {
|
|
|
|
return bukkitEntity;
|
|
|
|
}
|
2012-02-29 22:31:04 +01:00
|
|
|
CraftInventory inventory = new CraftInventory(this.brewingStand);
|
|
|
|
bukkitEntity = new CraftInventoryView(this.player.player.getBukkitEntity(), inventory, this);
|
2012-02-29 19:56:35 +01:00
|
|
|
return bukkitEntity;
|
|
|
|
}
|
|
|
|
// CraftBukkit end
|
2012-02-26 05:56:31 +01:00
|
|
|
}
|