mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-12 11:21:31 +01:00
176 lines
8.6 KiB
Diff
176 lines
8.6 KiB
Diff
--- a/net/minecraft/server/BlockCauldron.java
|
|
+++ b/net/minecraft/server/BlockCauldron.java
|
|
@@ -3,6 +3,7 @@
|
|
import java.util.List;
|
|
import java.util.Random;
|
|
import javax.annotation.Nullable;
|
|
+import org.bukkit.event.block.CauldronLevelChangeEvent; // CraftBukkit
|
|
|
|
public class BlockCauldron extends Block {
|
|
|
|
@@ -43,8 +44,13 @@
|
|
float f = (float) blockposition.getY() + (6.0F + (float) (3 * i)) / 16.0F;
|
|
|
|
if (!world.isClientSide && entity.isBurning() && i > 0 && entity.getBoundingBox().b <= (double) f) {
|
|
+ // CraftBukkit start
|
|
+ if (!this.changeLevel(world, blockposition, iblockdata, i - 1, entity, CauldronLevelChangeEvent.ChangeReason.EXTINGUISH)) {
|
|
+ return;
|
|
+ }
|
|
entity.extinguish();
|
|
- this.a(world, blockposition, iblockdata, i - 1);
|
|
+ // this.a(world, blockposition, iblockdata, i - 1);
|
|
+ // CraftBukkit end
|
|
}
|
|
|
|
}
|
|
@@ -60,18 +66,27 @@
|
|
|
|
if (item == Items.WATER_BUCKET) {
|
|
if (i < 3 && !world.isClientSide) {
|
|
+ // CraftBukkit start
|
|
+ if (!this.changeLevel(world, blockposition, iblockdata, 3, entityhuman, CauldronLevelChangeEvent.ChangeReason.BUCKET_EMPTY)) {
|
|
+ return true;
|
|
+ }
|
|
if (!entityhuman.abilities.canInstantlyBuild) {
|
|
entityhuman.a(enumhand, new ItemStack(Items.BUCKET));
|
|
}
|
|
|
|
entityhuman.b(StatisticList.I);
|
|
- this.a(world, blockposition, iblockdata, 3);
|
|
+ // this.a(world, blockposition, iblockdata, 3);
|
|
+ // CraftBukkit end
|
|
world.a((EntityHuman) null, blockposition, SoundEffects.Q, SoundCategory.BLOCKS, 1.0F, 1.0F);
|
|
}
|
|
|
|
return true;
|
|
} else if (item == Items.BUCKET) {
|
|
if (i == 3 && !world.isClientSide) {
|
|
+ // CraftBukkit start
|
|
+ if (!this.changeLevel(world, blockposition, iblockdata, 0, entityhuman, CauldronLevelChangeEvent.ChangeReason.BUCKET_FILL)) {
|
|
+ return true;
|
|
+ }
|
|
if (!entityhuman.abilities.canInstantlyBuild) {
|
|
itemstack.subtract(1);
|
|
if (itemstack.isEmpty()) {
|
|
@@ -82,7 +97,8 @@
|
|
}
|
|
|
|
entityhuman.b(StatisticList.J);
|
|
- this.a(world, blockposition, iblockdata, 0);
|
|
+ // this.a(world, blockposition, iblockdata, 0);
|
|
+ // CraftBukkit end
|
|
world.a((EntityHuman) null, blockposition, SoundEffects.S, SoundCategory.BLOCKS, 1.0F, 1.0F);
|
|
}
|
|
|
|
@@ -92,6 +108,10 @@
|
|
|
|
if (item == Items.GLASS_BOTTLE) {
|
|
if (i > 0 && !world.isClientSide) {
|
|
+ // CraftBukkit start
|
|
+ if (!this.changeLevel(world, blockposition, iblockdata, i - 1, entityhuman, CauldronLevelChangeEvent.ChangeReason.BOTTLE_FILL)) {
|
|
+ return true;
|
|
+ }
|
|
if (!entityhuman.abilities.canInstantlyBuild) {
|
|
itemstack1 = PotionUtil.a(new ItemStack(Items.POTION), Potions.b);
|
|
entityhuman.b(StatisticList.J);
|
|
@@ -106,12 +126,17 @@
|
|
}
|
|
|
|
world.a((EntityHuman) null, blockposition, SoundEffects.N, SoundCategory.BLOCKS, 1.0F, 1.0F);
|
|
- this.a(world, blockposition, iblockdata, i - 1);
|
|
+ // this.a(world, blockposition, iblockdata, i - 1);
|
|
+ // CraftBukkit end
|
|
}
|
|
|
|
return true;
|
|
} else if (item == Items.POTION && PotionUtil.d(itemstack) == Potions.b) {
|
|
if (i < 3 && !world.isClientSide) {
|
|
+ // CraftBukkit start
|
|
+ if (!this.changeLevel(world, blockposition, iblockdata, i + 1, entityhuman, CauldronLevelChangeEvent.ChangeReason.BOTTLE_EMPTY)) {
|
|
+ return true;
|
|
+ }
|
|
if (!entityhuman.abilities.canInstantlyBuild) {
|
|
itemstack1 = new ItemStack(Items.GLASS_BOTTLE);
|
|
entityhuman.b(StatisticList.J);
|
|
@@ -122,7 +147,8 @@
|
|
}
|
|
|
|
world.a((EntityHuman) null, blockposition, SoundEffects.M, SoundCategory.BLOCKS, 1.0F, 1.0F);
|
|
- this.a(world, blockposition, iblockdata, i + 1);
|
|
+ // this.a(world, blockposition, iblockdata, i + 1);
|
|
+ // CraftBukkit end
|
|
}
|
|
|
|
return true;
|
|
@@ -131,8 +157,13 @@
|
|
ItemArmor itemarmor = (ItemArmor) item;
|
|
|
|
if (itemarmor.d() == ItemArmor.EnumArmorMaterial.LEATHER && itemarmor.e_(itemstack) && !world.isClientSide) {
|
|
+ // CraftBukkit start
|
|
+ if (!this.changeLevel(world, blockposition, iblockdata, i - 1, entityhuman, CauldronLevelChangeEvent.ChangeReason.ARMOR_WASH)) {
|
|
+ return true;
|
|
+ }
|
|
itemarmor.d(itemstack);
|
|
- this.a(world, blockposition, iblockdata, i - 1);
|
|
+ // this.a(world, blockposition, iblockdata, i - 1);
|
|
+ // CraftBukkit end
|
|
entityhuman.b(StatisticList.K);
|
|
return true;
|
|
}
|
|
@@ -140,13 +171,18 @@
|
|
|
|
if (i > 0 && item instanceof ItemBanner) {
|
|
if (TileEntityBanner.b(itemstack) > 0 && !world.isClientSide) {
|
|
+ // CraftBukkit start
|
|
+ if (!this.changeLevel(world, blockposition, iblockdata, i - 1, entityhuman, CauldronLevelChangeEvent.ChangeReason.BANNER_WASH)) {
|
|
+ return true;
|
|
+ }
|
|
itemstack1 = itemstack.cloneItemStack();
|
|
itemstack1.setCount(1);
|
|
TileEntityBanner.c(itemstack1);
|
|
entityhuman.b(StatisticList.L);
|
|
if (!entityhuman.abilities.canInstantlyBuild) {
|
|
itemstack.subtract(1);
|
|
- this.a(world, blockposition, iblockdata, i - 1);
|
|
+ // this.a(world, blockposition, iblockdata, i - 1);
|
|
+ // CraftBukkit end
|
|
}
|
|
|
|
if (itemstack.isEmpty()) {
|
|
@@ -167,9 +203,25 @@
|
|
}
|
|
}
|
|
|
|
+ // CraftBukkit start
|
|
public void a(World world, BlockPosition blockposition, IBlockData iblockdata, int i) {
|
|
- world.setTypeAndData(blockposition, iblockdata.set(BlockCauldron.LEVEL, Integer.valueOf(MathHelper.clamp(i, 0, 3))), 2);
|
|
+ this.changeLevel(world, blockposition, iblockdata, i, null, CauldronLevelChangeEvent.ChangeReason.UNKNOWN);
|
|
+ }
|
|
+
|
|
+ private boolean changeLevel(World world, BlockPosition blockposition, IBlockData iblockdata, int i, Entity entity, CauldronLevelChangeEvent.ChangeReason reason) {
|
|
+ int newLevel = Integer.valueOf(MathHelper.clamp(i, 0, 3));
|
|
+ CauldronLevelChangeEvent event = new CauldronLevelChangeEvent(
|
|
+ world.getWorld().getBlockAt(blockposition.getX(), blockposition.getY(), blockposition.getZ()),
|
|
+ (entity == null) ? null : entity.getBukkitEntity(), reason, iblockdata.get(BlockCauldron.LEVEL), newLevel
|
|
+ );
|
|
+ world.getServer().getPluginManager().callEvent(event);
|
|
+ if (event.isCancelled()) {
|
|
+ return false;
|
|
+ }
|
|
+ world.setTypeAndData(blockposition, iblockdata.set(BlockCauldron.LEVEL, newLevel), 2);
|
|
world.updateAdjacentComparators(blockposition, this);
|
|
+ return true;
|
|
+ // CraftBukkit end
|
|
}
|
|
|
|
public void h(World world, BlockPosition blockposition) {
|
|
@@ -180,7 +232,7 @@
|
|
IBlockData iblockdata = world.getType(blockposition);
|
|
|
|
if (((Integer) iblockdata.get(BlockCauldron.LEVEL)).intValue() < 3) {
|
|
- world.setTypeAndData(blockposition, iblockdata.a((IBlockState) BlockCauldron.LEVEL), 2);
|
|
+ this.a(world, blockposition, iblockdata.a((IBlockState) BlockCauldron.LEVEL), 2); // CraftBukkit
|
|
}
|
|
|
|
}
|