summaryrefslogtreecommitdiffstats
path: root/src/main/java/net/minecraft/server/ItemHoe.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/net/minecraft/server/ItemHoe.java')
-rw-r--r--src/main/java/net/minecraft/server/ItemHoe.java90
1 files changed, 45 insertions, 45 deletions
diff --git a/src/main/java/net/minecraft/server/ItemHoe.java b/src/main/java/net/minecraft/server/ItemHoe.java
index d60829a7..0b4849d4 100644
--- a/src/main/java/net/minecraft/server/ItemHoe.java
+++ b/src/main/java/net/minecraft/server/ItemHoe.java
@@ -1,7 +1,5 @@
package net.minecraft.server;
-import java.util.Random;
-
// CraftBukkit start
import org.bukkit.block.BlockFace;
import org.bukkit.craftbukkit.CraftServer;
@@ -17,58 +15,60 @@ public class ItemHoe extends Item {
public ItemHoe(int i, EnumToolMaterial enumtoolmaterial) {
super(i);
- bb = 1;
- bc = enumtoolmaterial.a();
+ this.maxStackSize = 1;
+ this.durability = enumtoolmaterial.a();
}
- public boolean a(ItemStack itemstack, EntityPlayer entityplayer, World world, int i, int j, int k, int l) {
- int i1 = world.a(i, j, k);
- Material material = world.c(i, j + 1, k);
-
- if (!material.a() && i1 == Block.u.bi || i1 == Block.v.bi) {
- // CraftBukkit start - Hoes
- CraftWorld craftWorld = ((WorldServer) world).getWorld();
- CraftServer craftServer = ((WorldServer) world).getServer();
-
- Type eventType = Type.PLAYER_ITEM;
- Player who = (entityplayer == null)?null:(Player)entityplayer.getBukkitEntity();
- org.bukkit.inventory.ItemStack itemInHand = new CraftItemStack(itemstack);
- org.bukkit.block.Block blockClicked = craftWorld.getBlockAt(i, j, k);
- BlockFace blockFace = CraftBlock.notchToBlockFace(1);
-
- PlayerItemEvent pie = new PlayerItemEvent(eventType, who, itemInHand, blockClicked, blockFace);
- craftServer.getPluginManager().callEvent(pie);
-
- if (pie.isCancelled()) {
- return false;
- }
- // CraftBukkit end
+ public boolean a(ItemStack itemstack, EntityHuman entityhuman, World world, int i, int j, int k, int l) {
+ int i1 = world.getTypeId(i, j, k);
+ Material material = world.getMaterial(i, j + 1, k);
- Block block = Block.aA;
+ if ((material.isBuildable() || i1 != Block.GRASS.id) && i1 != Block.DIRT.id) {
+ return false;
+ } else {
+ Block block = Block.SOIL;
- world.a((float) i + 0.5F, (float) j + 0.5F, (float) k + 0.5F, block.br.c(), (block.br.a() + 1.0F) / 2.0F, block.br.b() * 0.8F);
- if (world.z) {
+ world.a((double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), block.stepSound.c(), (block.stepSound.a() + 1.0F) / 2.0F, block.stepSound.b() * 0.8F);
+ if (world.isStatic) {
return true;
- }
- world.e(i, j, k, block.bi);
- itemstack.b(1);
- if (world.l.nextInt(8) == 0 && i1 == Block.u.bi) {
- int j1 = 1;
+ } else {
+ // CraftBukkit start - Hoes
+ CraftWorld craftWorld = ((WorldServer) world).getWorld();
+ CraftServer craftServer = ((WorldServer) world).getServer();
- for (int k1 = 0; k1 < j1; k1++) {
- float f = 0.7F;
- float f1 = world.l.nextFloat() * f + (1.0F - f) * 0.5F;
- float f2 = 1.2F;
- float f3 = world.l.nextFloat() * f + (1.0F - f) * 0.5F;
- EntityItem entityitem = new EntityItem(world, (float) i + f1, (float) j + f2, (float) k + f3, new ItemStack(Item.Q));
+ Type eventType = Type.PLAYER_ITEM;
+ Player who = (entityhuman == null) ? null : (Player) entityhuman.getBukkitEntity();
+ org.bukkit.inventory.ItemStack itemInHand = new CraftItemStack(itemstack);
+ org.bukkit.block.Block blockClicked = craftWorld.getBlockAt(i, j, k);
+ BlockFace blockFace = CraftBlock.notchToBlockFace(1);
- entityitem.c = 10;
- world.a(((Entity) (entityitem)));
+ PlayerItemEvent event = new PlayerItemEvent(eventType, who, itemInHand, blockClicked, blockFace);
+ craftServer.getPluginManager().callEvent(event);
+
+ if (event.isCancelled()) {
+ return false;
}
+ // CraftBukkit end
+
+ world.e(i, j, k, block.id);
+ itemstack.b(1);
+ if (world.l.nextInt(8) == 0 && i1 == Block.GRASS.id) {
+ byte b0 = 1;
+
+ for (int j1 = 0; j1 < b0; ++j1) {
+ float f = 0.7F;
+ float f1 = world.l.nextFloat() * f + (1.0F - f) * 0.5F;
+ float f2 = 1.2F;
+ float f3 = world.l.nextFloat() * f + (1.0F - f) * 0.5F;
+ EntityItem entityitem = new EntityItem(world, (double) ((float) i + f1), (double) ((float) j + f2), (double) ((float) k + f3), new ItemStack(Item.SEEDS));
+
+ entityitem.c = 10;
+ world.a((Entity) entityitem);
+ }
+ }
+
+ return true;
}
- return true;
- } else {
- return false;
}
}
}