diff options
author | Thinkofdeath <thinkofdeath@spigotmc.org> | 2014-11-26 08:32:16 +1100 |
---|---|---|
committer | md_5 <git@md-5.net> | 2014-11-28 17:16:30 +1100 |
commit | 24557bc2b37deb6a0edf497d547471832457b1dd (patch) | |
tree | c560572889a3b0b34964a0cddb35dc87fda3c914 /src/main/java/net/minecraft/server/ItemBucket.java | |
parent | a4805dbd77da057cc1ea0bf344379bc6e53ca1f6 (diff) | |
download | craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar.gz craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar.lz craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar.xz craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.zip |
Update to Minecraft 1.8
For more information please see http://www.spigotmc.org/
Diffstat (limited to 'src/main/java/net/minecraft/server/ItemBucket.java')
-rw-r--r-- | src/main/java/net/minecraft/server/ItemBucket.java | 171 |
1 files changed, 0 insertions, 171 deletions
diff --git a/src/main/java/net/minecraft/server/ItemBucket.java b/src/main/java/net/minecraft/server/ItemBucket.java deleted file mode 100644 index a58d4e73..00000000 --- a/src/main/java/net/minecraft/server/ItemBucket.java +++ /dev/null @@ -1,171 +0,0 @@ -package net.minecraft.server; - -// CraftBukkit start -import org.bukkit.craftbukkit.event.CraftEventFactory; -import org.bukkit.craftbukkit.inventory.CraftItemStack; -import org.bukkit.event.player.PlayerBucketEmptyEvent; -import org.bukkit.event.player.PlayerBucketFillEvent; -// CraftBukkit end - -public class ItemBucket extends Item { - - private Block a; - - public ItemBucket(Block block) { - this.maxStackSize = 1; - this.a = block; - this.a(CreativeModeTab.f); - } - - public ItemStack a(ItemStack itemstack, World world, EntityHuman entityhuman) { - boolean flag = this.a == Blocks.AIR; - MovingObjectPosition movingobjectposition = this.a(world, entityhuman, flag); - - if (movingobjectposition == null) { - return itemstack; - } else { - if (movingobjectposition.type == EnumMovingObjectType.BLOCK) { - int i = movingobjectposition.b; - int j = movingobjectposition.c; - int k = movingobjectposition.d; - - if (!world.a(entityhuman, i, j, k)) { - return itemstack; - } - - if (flag) { - if (!entityhuman.a(i, j, k, movingobjectposition.face, itemstack)) { - return itemstack; - } - - Material material = world.getType(i, j, k).getMaterial(); - int l = world.getData(i, j, k); - - if (material == Material.WATER && l == 0) { - // CraftBukkit start - PlayerBucketFillEvent event = CraftEventFactory.callPlayerBucketFillEvent(entityhuman, i, j, k, -1, itemstack, Items.WATER_BUCKET); - - if (event.isCancelled()) { - return itemstack; - } - // CraftBukkit end - world.setAir(i, j, k); - return this.a(itemstack, entityhuman, Items.WATER_BUCKET, event.getItemStack()); // CraftBukkit - added Event stack - } - - if (material == Material.LAVA && l == 0) { - // CraftBukkit start - PlayerBucketFillEvent event = CraftEventFactory.callPlayerBucketFillEvent(entityhuman, i, j, k, -1, itemstack, Items.LAVA_BUCKET); - - if (event.isCancelled()) { - return itemstack; - } - // CraftBukkit end - world.setAir(i, j, k); - return this.a(itemstack, entityhuman, Items.LAVA_BUCKET, event.getItemStack()); // CraftBukkit - added Event stack - } - } else { - if (this.a == Blocks.AIR) { - // CraftBukkit start - PlayerBucketEmptyEvent event = CraftEventFactory.callPlayerBucketEmptyEvent(entityhuman, i, j, k, movingobjectposition.face, itemstack); - - if (event.isCancelled()) { - return itemstack; - } - - return CraftItemStack.asNMSCopy(event.getItemStack()); - } - - int clickedX = i, clickedY = j, clickedZ = k; - // CraftBukkit end - - if (movingobjectposition.face == 0) { - --j; - } - - if (movingobjectposition.face == 1) { - ++j; - } - - if (movingobjectposition.face == 2) { - --k; - } - - if (movingobjectposition.face == 3) { - ++k; - } - - if (movingobjectposition.face == 4) { - --i; - } - - if (movingobjectposition.face == 5) { - ++i; - } - - if (!entityhuman.a(i, j, k, movingobjectposition.face, itemstack)) { - return itemstack; - } - - // CraftBukkit start - PlayerBucketEmptyEvent event = CraftEventFactory.callPlayerBucketEmptyEvent(entityhuman, clickedX, clickedY, clickedZ, movingobjectposition.face, itemstack); - - if (event.isCancelled()) { - return itemstack; - } - // CraftBukkit end - - if (this.a(world, i, j, k) && !entityhuman.abilities.canInstantlyBuild) { - return CraftItemStack.asNMSCopy(event.getItemStack()); // CraftBukkit - } - } - } - - return itemstack; - } - } - - // CraftBukkit - added ob.ItemStack result - TODO: Is this... the right way to handle this? - private ItemStack a(ItemStack itemstack, EntityHuman entityhuman, Item item, org.bukkit.inventory.ItemStack result) { - if (entityhuman.abilities.canInstantlyBuild) { - return itemstack; - } else if (--itemstack.count <= 0) { - return CraftItemStack.asNMSCopy(result); // CraftBukkit - } else { - if (!entityhuman.inventory.pickup(CraftItemStack.asNMSCopy(result))) { // CraftBukkit - entityhuman.drop(CraftItemStack.asNMSCopy(result), false); // CraftBukkit - } - - return itemstack; - } - } - - public boolean a(World world, int i, int j, int k) { - if (this.a == Blocks.AIR) { - return false; - } else { - Material material = world.getType(i, j, k).getMaterial(); - boolean flag = !material.isBuildable(); - - if (!world.isEmpty(i, j, k) && !flag) { - return false; - } else { - if (world.worldProvider.f && this.a == Blocks.WATER) { - world.makeSound((double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), "random.fizz", 0.5F, 2.6F + (world.random.nextFloat() - world.random.nextFloat()) * 0.8F); - - for (int l = 0; l < 8; ++l) { - world.addParticle("largesmoke", (double) i + Math.random(), (double) j + Math.random(), (double) k + Math.random(), 0.0D, 0.0D, 0.0D); - } - } else { - if (!world.isStatic && flag && !material.isLiquid()) { - world.setAir(i, j, k, true); - } - - world.setTypeAndData(i, j, k, this.a, 0, 3); - } - - return true; - } - } - } -} |