mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 21:31:25 +01:00
33 lines
2.1 KiB
Diff
33 lines
2.1 KiB
Diff
--- a/net/minecraft/server/EnchantmentFrostWalker.java
|
|
+++ b/net/minecraft/server/EnchantmentFrostWalker.java
|
|
@@ -1,5 +1,8 @@
|
|
package net.minecraft.server;
|
|
|
|
+import org.bukkit.craftbukkit.util.CraftMagicNumbers;
|
|
+import org.bukkit.event.block.EntityBlockFormEvent;
|
|
+
|
|
import java.util.Iterator;
|
|
|
|
public class EnchantmentFrostWalker extends Enchantment {
|
|
@@ -42,8 +45,18 @@
|
|
IBlockData iblockdata1 = world.getType(blockposition_mutableblockposition1);
|
|
|
|
if (iblockdata1.getMaterial() == Material.WATER && ((Integer) iblockdata1.get(BlockFluids.LEVEL)).intValue() == 0 && world.a(Blocks.FROSTED_ICE, blockposition_mutableblockposition1, false, EnumDirection.DOWN, (Entity) null)) {
|
|
- world.setTypeUpdate(blockposition_mutableblockposition1, Blocks.FROSTED_ICE.getBlockData());
|
|
- world.a(blockposition_mutableblockposition1.h(), Blocks.FROSTED_ICE, MathHelper.nextInt(entityliving.getRandom(), 60, 120));
|
|
+ // CraftBukkit Start - Call EntityBlockFormEvent for Frost Walker
|
|
+ org.bukkit.block.BlockState blockState = world.getWorld().getBlockAt(blockposition_mutableblockposition1.getX(), blockposition_mutableblockposition1.getY(), blockposition_mutableblockposition1.getZ()).getState();
|
|
+ blockState.setType(CraftMagicNumbers.getMaterial(Blocks.FROSTED_ICE));
|
|
+
|
|
+ EntityBlockFormEvent event = new EntityBlockFormEvent(entityliving.bukkitEntity, blockState.getBlock(), blockState);
|
|
+ world.getServer().getPluginManager().callEvent(event);
|
|
+
|
|
+ if (!event.isCancelled()) {
|
|
+ blockState.update(true);
|
|
+ world.a(blockposition_mutableblockposition1.h(), Blocks.FROSTED_ICE, MathHelper.nextInt(entityliving.getRandom(), 60, 120));
|
|
+ }
|
|
+ // CraftBukkit End
|
|
}
|
|
}
|
|
}
|