2021-03-16 09:00:00 +11:00
|
|
|
--- a/net/minecraft/world/entity/animal/EntityCat.java
|
|
|
|
+++ b/net/minecraft/world/entity/animal/EntityCat.java
|
2022-12-08 03:00:00 +11:00
|
|
|
@@ -415,7 +415,7 @@
|
2019-12-11 09:00:00 +11:00
|
|
|
}
|
2021-11-22 09:00:00 +11:00
|
|
|
} else if (this.isFood(itemstack)) {
|
|
|
|
this.usePlayerItem(entityhuman, enumhand, itemstack);
|
2019-05-19 12:02:25 +10:00
|
|
|
- if (this.random.nextInt(3) == 0) {
|
|
|
|
+ if (this.random.nextInt(3) == 0 && !org.bukkit.craftbukkit.event.CraftEventFactory.callEntityTameEvent(this, entityhuman).isCancelled()) { // CraftBukkit
|
|
|
|
this.tame(entityhuman);
|
2021-11-22 09:00:00 +11:00
|
|
|
this.setOrderedToSit(true);
|
|
|
|
this.level.broadcastEntityEvent(this, (byte) 7);
|
2022-12-08 03:00:00 +11:00
|
|
|
@@ -472,7 +472,7 @@
|
2021-06-11 15:00:00 +10:00
|
|
|
private static class PathfinderGoalTemptChance extends PathfinderGoalTempt {
|
|
|
|
|
|
|
|
@Nullable
|
|
|
|
- private EntityHuman selectedPlayer;
|
|
|
|
+ private EntityLiving selectedPlayer; // CraftBukkit
|
|
|
|
private final EntityCat cat;
|
|
|
|
|
|
|
|
public PathfinderGoalTemptChance(EntityCat entitycat, double d0, RecipeItemStack recipeitemstack, boolean flag) {
|
2022-12-08 03:00:00 +11:00
|
|
|
@@ -613,7 +613,15 @@
|
2021-01-21 08:31:06 +11:00
|
|
|
while (iterator.hasNext()) {
|
|
|
|
ItemStack itemstack = (ItemStack) iterator.next();
|
|
|
|
|
2021-11-22 09:00:00 +11:00
|
|
|
- this.cat.level.addFreshEntity(new EntityItem(this.cat.level, (double) blockposition_mutableblockposition.getX() - (double) MathHelper.sin(this.cat.yBodyRot * 0.017453292F), (double) blockposition_mutableblockposition.getY(), (double) blockposition_mutableblockposition.getZ() + (double) MathHelper.cos(this.cat.yBodyRot * 0.017453292F), itemstack));
|
2021-01-21 08:31:06 +11:00
|
|
|
+ // CraftBukkit start
|
2021-06-11 15:00:00 +10:00
|
|
|
+ EntityItem entityitem = new EntityItem(this.cat.level, (double) blockposition_mutableblockposition.getX() - (double) MathHelper.sin(this.cat.yBodyRot * 0.017453292F), (double) blockposition_mutableblockposition.getY(), (double) blockposition_mutableblockposition.getZ() + (double) MathHelper.cos(this.cat.yBodyRot * 0.017453292F), itemstack);
|
|
|
|
+ org.bukkit.event.entity.EntityDropItemEvent event = new org.bukkit.event.entity.EntityDropItemEvent(this.cat.getBukkitEntity(), (org.bukkit.entity.Item) entityitem.getBukkitEntity());
|
2021-06-11 21:33:49 +10:00
|
|
|
+ entityitem.level.getCraftServer().getPluginManager().callEvent(event);
|
2021-01-21 08:31:06 +11:00
|
|
|
+ if (event.isCancelled()) {
|
2021-02-07 08:45:11 +11:00
|
|
|
+ continue;
|
2021-01-21 08:31:06 +11:00
|
|
|
+ }
|
2021-11-22 09:00:00 +11:00
|
|
|
+ this.cat.level.addFreshEntity(entityitem);
|
2021-01-21 08:31:06 +11:00
|
|
|
+ // CraftBukkit end
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2022-12-08 03:00:00 +11:00
|
|
|
@@ -645,10 +653,10 @@
|
2021-06-11 15:00:00 +10:00
|
|
|
private final EntityCat cat;
|
2019-04-23 12:00:00 +10:00
|
|
|
|
|
|
|
public a(EntityCat entitycat, Class<T> oclass, float f, double d0, double d1) {
|
2021-06-11 15:00:00 +10:00
|
|
|
- Predicate predicate = IEntitySelector.NO_CREATIVE_OR_SPECTATOR;
|
2021-11-22 09:00:00 +11:00
|
|
|
+ // Predicate predicate = IEntitySelector.NO_CREATIVE_OR_SPECTATOR; // CraftBukkit - decompile error
|
2019-04-23 12:00:00 +10:00
|
|
|
|
2021-06-11 15:00:00 +10:00
|
|
|
- Objects.requireNonNull(predicate);
|
2019-04-23 12:00:00 +10:00
|
|
|
- super(entitycat, oclass, f, d0, d1, predicate::test);
|
2021-06-11 15:00:00 +10:00
|
|
|
+ // Objects.requireNonNull(predicate); // CraftBukkit - decompile error
|
|
|
|
+ super(entitycat, oclass, f, d0, d1, IEntitySelector.NO_CREATIVE_OR_SPECTATOR::test); // CraftBukkit - decompile error
|
|
|
|
this.cat = entitycat;
|
2019-04-23 12:00:00 +10:00
|
|
|
}
|
|
|
|
|