2022-04-23 21:38:42 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
|
|
|
Date: Fri, 18 Mar 2022 21:15:55 -0700
|
|
|
|
Subject: [PATCH] Add EntityDyeEvent and CollarColorable interface
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/animal/Cat.java b/src/main/java/net/minecraft/world/entity/animal/Cat.java
|
2022-06-08 15:36:56 +02:00
|
|
|
index 5ad968a2f1add27da0d6a858e683d5d771128092..4e42bcb48c75c816e89e652c898242a9bd8c9d5a 100644
|
2022-04-23 21:38:42 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/animal/Cat.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/animal/Cat.java
|
2022-06-08 15:36:56 +02:00
|
|
|
@@ -399,6 +399,13 @@ public class Cat extends TamableAnimal {
|
2022-04-23 21:38:42 +02:00
|
|
|
DyeColor enumcolor = ((DyeItem) item).getDyeColor();
|
|
|
|
|
|
|
|
if (enumcolor != this.getCollarColor()) {
|
|
|
|
+ // Paper start
|
|
|
|
+ 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
|
|
|
|
this.setCollarColor(enumcolor);
|
|
|
|
if (!player.getAbilities().instabuild) {
|
|
|
|
itemstack.shrink(1);
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/animal/Wolf.java b/src/main/java/net/minecraft/world/entity/animal/Wolf.java
|
2022-06-08 15:36:56 +02:00
|
|
|
index 34dadacb8238896b799716875ea5d0e924c323e8..45c3cec839a7c23903dedf6e3e004305da2adceb 100644
|
2022-04-23 21:38:42 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/animal/Wolf.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/animal/Wolf.java
|
2022-06-08 15:36:56 +02:00
|
|
|
@@ -392,6 +392,13 @@ public class Wolf extends TamableAnimal implements NeutralMob {
|
2022-04-23 21:38:42 +02:00
|
|
|
DyeColor enumcolor = ((DyeItem) item).getDyeColor();
|
|
|
|
|
|
|
|
if (enumcolor != this.getCollarColor()) {
|
|
|
|
+ // Paper start
|
|
|
|
+ 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
|
|
|
|
this.setCollarColor(enumcolor);
|
|
|
|
if (!player.getAbilities().instabuild) {
|
|
|
|
itemstack.shrink(1);
|