diff options
author | durron597 <martin.jared@gmail.com> | 2011-01-08 06:18:05 -0500 |
---|---|---|
committer | durron597 <martin.jared@gmail.com> | 2011-01-08 06:18:05 -0500 |
commit | fab66092e2e5379c4f3fa9cf37f37320c8ac0e18 (patch) | |
tree | 511d1d2fb5d2bfbea9910eb8e57ae56074d71cba /src/main/java/net/minecraft/server/ItemMinecart.java | |
parent | 65c8df24b60443ee2c7932fd68d498694ec5ede2 (diff) | |
download | craftbukkit-fab66092e2e5379c4f3fa9cf37f37320c8ac0e18.tar craftbukkit-fab66092e2e5379c4f3fa9cf37f37320c8ac0e18.tar.gz craftbukkit-fab66092e2e5379c4f3fa9cf37f37320c8ac0e18.tar.lz craftbukkit-fab66092e2e5379c4f3fa9cf37f37320c8ac0e18.tar.xz craftbukkit-fab66092e2e5379c4f3fa9cf37f37320c8ac0e18.zip |
Fixed lack of calling callEvent(event), finished Item Use
Diffstat (limited to 'src/main/java/net/minecraft/server/ItemMinecart.java')
-rw-r--r-- | src/main/java/net/minecraft/server/ItemMinecart.java | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/src/main/java/net/minecraft/server/ItemMinecart.java b/src/main/java/net/minecraft/server/ItemMinecart.java new file mode 100644 index 00000000..dfbd443b --- /dev/null +++ b/src/main/java/net/minecraft/server/ItemMinecart.java @@ -0,0 +1,45 @@ +package net.minecraft.server; + +import org.bukkit.craftbukkit.CraftBlock; +import org.bukkit.craftbukkit.CraftItemStack; +import org.bukkit.craftbukkit.CraftPlayer; +import org.bukkit.event.Event.Type; +import org.bukkit.event.player.PlayerItemEvent; + + +public class ItemMinecart extends Item { + + public int a; + + public ItemMinecart(int i, int j) { + super(i); + aX = 1; + a = j; + } + + public boolean a(ItemStack itemstack, EntityPlayer entityplayer, World world, int i, int j, int k, int l) { + int i1 = world.a(i, j, k); + + if (i1 == Block.aG.bh) { + // Craftbukkit start + // Minecarts + CraftBlock blockClicked = (CraftBlock) ((WorldServer) world).getWorld().getBlockAt(i, j, k); + CraftItemStack itemInHand = new CraftItemStack(itemstack); + CraftPlayer thePlayer = new CraftPlayer(((WorldServer) world).getServer(), (EntityPlayerMP) entityplayer); + PlayerItemEvent pie = new PlayerItemEvent(Type.PLAYER_ITEM, thePlayer, itemInHand, blockClicked, CraftBlock.notchToBlockFace(l)); + + ((WorldServer) world).getServer().getPluginManager().callEvent(pie); + + if (pie.isCancelled()) return false; + + if (!world.z) { + world.a(new EntityMinecart(world, (float) i + 0.5F, (float) j + 0.5F, (float) k + 0.5F, a)); + } + itemstack.a--; + return true; + } else { + return false; + } + } +} + |