2015-05-25 20:37:24 +10:00
|
|
|
--- a/net/minecraft/server/PathfinderGoalEatTile.java
|
|
|
|
+++ b/net/minecraft/server/PathfinderGoalEatTile.java
|
2019-04-23 12:00:00 +10:00
|
|
|
@@ -3,6 +3,10 @@
|
|
|
|
import java.util.EnumSet;
|
2018-07-15 10:00:00 +10:00
|
|
|
import java.util.function.Predicate;
|
2014-11-26 08:32:16 +11:00
|
|
|
|
|
|
|
+// CraftBukkit start
|
|
|
|
+import org.bukkit.craftbukkit.event.CraftEventFactory;
|
|
|
|
+// CraftBukkit end
|
|
|
|
+
|
|
|
|
public class PathfinderGoalEatTile extends PathfinderGoal {
|
|
|
|
|
2018-07-15 10:00:00 +10:00
|
|
|
private static final Predicate<IBlockData> a = BlockStatePredicate.a(Blocks.GRASS);
|
2019-04-23 12:00:00 +10:00
|
|
|
@@ -55,7 +59,8 @@
|
2019-05-14 10:00:00 +10:00
|
|
|
BlockPosition blockposition = new BlockPosition(this.b);
|
2014-11-26 08:32:16 +11:00
|
|
|
|
2018-07-15 10:00:00 +10:00
|
|
|
if (PathfinderGoalEatTile.a.test(this.c.getType(blockposition))) {
|
2019-06-21 20:00:00 +10:00
|
|
|
- if (this.c.getGameRules().getBoolean(GameRules.MOB_GRIEFING)) {
|
2014-11-26 08:32:16 +11:00
|
|
|
+ // CraftBukkit
|
2019-06-21 20:00:00 +10:00
|
|
|
+ if (!CraftEventFactory.callEntityChangeBlockEvent(this.b, blockposition, Blocks.AIR.getBlockData(), !this.c.getGameRules().getBoolean(GameRules.MOB_GRIEFING)).isCancelled()) {
|
2019-04-23 12:00:00 +10:00
|
|
|
this.c.b(blockposition, false);
|
2014-11-26 08:32:16 +11:00
|
|
|
}
|
|
|
|
|
2019-04-23 12:00:00 +10:00
|
|
|
@@ -64,7 +69,8 @@
|
2014-11-26 08:32:16 +11:00
|
|
|
BlockPosition blockposition1 = blockposition.down();
|
|
|
|
|
2018-07-15 10:00:00 +10:00
|
|
|
if (this.c.getType(blockposition1).getBlock() == Blocks.GRASS_BLOCK) {
|
2019-06-21 20:00:00 +10:00
|
|
|
- if (this.c.getGameRules().getBoolean(GameRules.MOB_GRIEFING)) {
|
2014-11-26 08:32:16 +11:00
|
|
|
+ // CraftBukkit
|
2019-06-21 20:00:00 +10:00
|
|
|
+ if (!CraftEventFactory.callEntityChangeBlockEvent(this.b, blockposition, Blocks.AIR.getBlockData(), !this.c.getGameRules().getBoolean(GameRules.MOB_GRIEFING)).isCancelled()) {
|
2018-07-15 10:00:00 +10:00
|
|
|
this.c.triggerEffect(2001, blockposition1, Block.getCombinedId(Blocks.GRASS_BLOCK.getBlockData()));
|
|
|
|
this.c.setTypeAndData(blockposition1, Blocks.DIRT.getBlockData(), 2);
|
2014-11-26 08:32:16 +11:00
|
|
|
}
|