From 2e86b222288a056a30f590af799644a9bc637a60 Mon Sep 17 00:00:00 2001 From: Jake Potrebic Date: Fri, 18 Mar 2022 21:15:55 -0700 Subject: [PATCH] Add EntityDyeEvent and CollarColorable interface --- .../world/entity/animal/Cat.java.patch | 22 +++++++++++++++---- .../world/entity/animal/Wolf.java.patch | 21 +++++++++++++++--- 2 files changed, 36 insertions(+), 7 deletions(-) diff --git a/paper-server/patches/sources/net/minecraft/world/entity/animal/Cat.java.patch b/paper-server/patches/sources/net/minecraft/world/entity/animal/Cat.java.patch index a83874a095..78e9dc4ebc 100644 --- a/paper-server/patches/sources/net/minecraft/world/entity/animal/Cat.java.patch +++ b/paper-server/patches/sources/net/minecraft/world/entity/animal/Cat.java.patch @@ -22,7 +22,21 @@ this.setVariant((Holder) BuiltInRegistries.CAT_VARIANT.getOrThrow(CatVariant.ALL_BLACK)); this.setPersistenceRequired(); } -@@ -462,7 +462,7 @@ +@@ -386,6 +386,13 @@ + DyeColor enumcolor = itemdye.getDyeColor(); + + if (enumcolor != this.getCollarColor()) { ++ // Paper start - Add EntityDyeEvent and CollarColorable interface ++ final io.papermc.paper.event.entity.EntityDyeEvent event = new io.papermc.paper.event.entity.EntityDyeEvent(this.getBukkitEntity(), org.bukkit.DyeColor.getByWoolData((byte) enumcolor.getId()), ((net.minecraft.server.level.ServerPlayer) player).getBukkitEntity()); ++ if (!event.callEvent()) { ++ return InteractionResult.FAIL; ++ } ++ enumcolor = DyeColor.byId(event.getColor().getWoolData()); ++ // Paper end - Add EntityDyeEvent and CollarColorable interface + if (!this.level().isClientSide()) { + this.setCollarColor(enumcolor); + itemstack.consume(1, player); +@@ -462,7 +469,7 @@ } private void tryToTame(Player player) { @@ -31,7 +45,7 @@ this.tame(player); this.setOrderedToSit(true); this.level().broadcastEntityEvent(this, (byte) 7); -@@ -480,7 +480,7 @@ +@@ -480,7 +487,7 @@ private static class CatTemptGoal extends TemptGoal { @Nullable @@ -40,7 +54,7 @@ private final Cat cat; public CatTemptGoal(Cat cat, double speed, Predicate foodPredicate, boolean canBeScared) { -@@ -614,7 +614,15 @@ +@@ -614,7 +621,15 @@ this.cat.randomTeleport((double) (blockposition_mutableblockposition.getX() + randomsource.nextInt(11) - 5), (double) (blockposition_mutableblockposition.getY() + randomsource.nextInt(5) - 2), (double) (blockposition_mutableblockposition.getZ() + randomsource.nextInt(11) - 5), false); blockposition_mutableblockposition.set(this.cat.blockPosition()); this.cat.dropFromGiftLootTable(getServerLevel((Entity) this.cat), BuiltInLootTables.CAT_MORNING_GIFT, (worldserver, itemstack) -> { @@ -57,7 +71,7 @@ }); } -@@ -645,10 +653,10 @@ +@@ -645,10 +660,10 @@ private final Cat cat; public CatAvoidEntityGoal(Cat cat, Class fleeFromType, float distance, double slowSpeed, double fastSpeed) { diff --git a/paper-server/patches/sources/net/minecraft/world/entity/animal/Wolf.java.patch b/paper-server/patches/sources/net/minecraft/world/entity/animal/Wolf.java.patch index 550b440f16..b710ea2516 100644 --- a/paper-server/patches/sources/net/minecraft/world/entity/animal/Wolf.java.patch +++ b/paper-server/patches/sources/net/minecraft/world/entity/animal/Wolf.java.patch @@ -80,7 +80,22 @@ return InteractionResult.SUCCESS; } else { if (item instanceof DyeItem) { -@@ -440,7 +458,9 @@ +@@ -414,6 +432,14 @@ + DyeColor enumcolor = itemdye.getDyeColor(); + + if (enumcolor != this.getCollarColor()) { ++ // Paper start - Add EntityDyeEvent and CollarColorable interface ++ final io.papermc.paper.event.entity.EntityDyeEvent event = new io.papermc.paper.event.entity.EntityDyeEvent(this.getBukkitEntity(), org.bukkit.DyeColor.getByWoolData((byte) enumcolor.getId()), ((net.minecraft.server.level.ServerPlayer) player).getBukkitEntity()); ++ if (!event.callEvent()) { ++ return InteractionResult.FAIL; ++ } ++ enumcolor = DyeColor.byId(event.getColor().getWoolData()); ++ // Paper end - Add EntityDyeEvent and CollarColorable interface ++ + this.setCollarColor(enumcolor); + itemstack.consume(1, player); + return InteractionResult.SUCCESS; +@@ -440,7 +466,9 @@ if (world instanceof ServerLevel) { ServerLevel worldserver = (ServerLevel) world; @@ -90,7 +105,7 @@ } return InteractionResult.SUCCESS; -@@ -459,7 +479,7 @@ +@@ -459,7 +487,7 @@ this.setOrderedToSit(!this.isOrderedToSit()); this.jumping = false; this.navigation.stop(); @@ -99,7 +114,7 @@ return InteractionResult.SUCCESS.withoutItem(); } else { return enuminteractionresult; -@@ -477,7 +497,8 @@ +@@ -477,7 +505,8 @@ } private void tryToTame(Player player) {