Added CraftInventory.setContents(); made CraftInventory.setItem(), CraftInventory.getItem(), and CraftItemStack() damage-aware.

This commit is contained in:
sk89q 2011-01-15 14:56:35 -08:00
parent f78b8c12a6
commit 44ae0531e7
2 changed files with 23 additions and 2 deletions

View File

@ -41,8 +41,28 @@ public class CraftInventory implements org.bukkit.inventory.Inventory {
return items;
}
public void setContents(ItemStack[] items) {
if (getInventory().getContents().length != items.length) {
throw new IllegalArgumentException("Invalid inventory size; expected "
+ getInventory().getContents().length);
}
net.minecraft.server.ItemStack[] mcItems = getInventory().getContents();
for (int i = 0; i < items.length; i++ ) {
ItemStack item = items[i];
if (item == null) {
mcItems[i] = null;
} else {
mcItems[i] = new net.minecraft.server.ItemStack(
item.getTypeId(), item.getAmount(), item.getDamage());
}
}
}
public void setItem(int index, ItemStack item) {
getInventory().a( index, new net.minecraft.server.ItemStack( item.getTypeId(), item.getAmount(), 0));
getInventory().a(index, new net.minecraft.server.ItemStack(
item.getTypeId(), item.getAmount(), item.getDamage()));
}
public boolean contains(int materialId) {

View File

@ -7,7 +7,8 @@ public class CraftItemStack extends ItemStack {
protected net.minecraft.server.ItemStack item;
public CraftItemStack(net.minecraft.server.ItemStack item) {
super(item != null ? item.c : 0, item != null ? item.a : 0);
super(item != null ? item.c : 0, item != null ? item.a : 0,
(byte)(item != null ? item.d : 0));
this.item = item;
}