AnvilDamageEvent

This commit is contained in:
BillyGalbreath 2018-07-20 23:37:03 -05:00
parent fb64feeb61
commit f20fbf5477

View file

@ -41,7 +41,24 @@
this.inputSlots.setItem(0, ItemStack.EMPTY); this.inputSlots.setItem(0, ItemStack.EMPTY);
this.access.execute((world, blockposition) -> { this.access.execute((world, blockposition) -> {
BlockState iblockdata = world.getBlockState(blockposition); BlockState iblockdata = world.getBlockState(blockposition);
@@ -143,8 +152,8 @@ @@ -102,6 +111,16 @@
if (!player.hasInfiniteMaterials() && iblockdata.is(BlockTags.ANVIL) && player.getRandom().nextFloat() < 0.12F) {
BlockState iblockdata1 = AnvilBlock.damage(iblockdata);
+ // Paper start - AnvilDamageEvent
+ com.destroystokyo.paper.event.block.AnvilDamagedEvent event = new com.destroystokyo.paper.event.block.AnvilDamagedEvent(getBukkitView(), iblockdata1 != null ? org.bukkit.craftbukkit.block.data.CraftBlockData.fromData(iblockdata1) : null);
+ if (!event.callEvent()) {
+ return;
+ } else if (event.getDamageState() == com.destroystokyo.paper.event.block.AnvilDamagedEvent.DamageState.BROKEN) {
+ iblockdata1 = null;
+ } else {
+ iblockdata1 = ((org.bukkit.craftbukkit.block.data.CraftBlockData) event.getDamageState().getMaterial().createBlockData()).getState().setValue(AnvilBlock.FACING, iblockdata.getValue(AnvilBlock.FACING));
+ }
+ // Paper end - AnvilDamageEvent
if (iblockdata1 == null) {
world.removeBlock(blockposition, false);
world.levelEvent(1029, blockposition, 0);
@@ -143,8 +162,8 @@
if (itemstack1.isDamageableItem() && itemstack.isValidRepairItem(itemstack2)) { if (itemstack1.isDamageableItem() && itemstack.isValidRepairItem(itemstack2)) {
k = Math.min(itemstack1.getDamageValue(), itemstack1.getMaxDamage() / 4); k = Math.min(itemstack1.getDamageValue(), itemstack1.getMaxDamage() / 4);
if (k <= 0) { if (k <= 0) {
@ -52,7 +69,7 @@
return; return;
} }
@@ -158,8 +167,8 @@ @@ -158,8 +177,8 @@
this.repairItemCountCost = i1; this.repairItemCountCost = i1;
} else { } else {
if (!flag && (!itemstack1.is(itemstack2.getItem()) || !itemstack1.isDamageableItem())) { if (!flag && (!itemstack1.is(itemstack2.getItem()) || !itemstack1.isDamageableItem())) {
@ -63,7 +80,7 @@
return; return;
} }
@@ -233,8 +242,8 @@ @@ -233,8 +252,8 @@
} }
if (flag2 && !flag1) { if (flag2 && !flag1) {
@ -74,7 +91,7 @@
return; return;
} }
} }
@@ -260,14 +269,14 @@ @@ -260,14 +279,14 @@
} }
if (b0 == i && b0 > 0) { if (b0 == i && b0 > 0) {
@ -92,7 +109,7 @@
itemstack1 = ItemStack.EMPTY; itemstack1 = ItemStack.EMPTY;
} }
@@ -285,12 +294,13 @@ @@ -285,12 +304,13 @@
EnchantmentHelper.setEnchantments(itemstack1, itemenchantments_a.toImmutable()); EnchantmentHelper.setEnchantments(itemstack1, itemenchantments_a.toImmutable());
} }
@ -109,7 +126,7 @@
} }
public static int calculateIncreasedRepairCost(int cost) { public static int calculateIncreasedRepairCost(int cost) {
@@ -329,4 +339,19 @@ @@ -329,4 +349,19 @@
public int getCost() { public int getCost() {
return this.cost.get(); return this.cost.get();
} }