diff options
Diffstat (limited to 'src/main/java/net/minecraft/server/ItemHoe.java')
-rw-r--r-- | src/main/java/net/minecraft/server/ItemHoe.java | 90 |
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; } } } |