mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-20 07:34:48 +01:00
Add ZombieVillager conversion without entity event (#8111)
The ZombieVillager#setConversionTime API method internally calls startConversion which always broadcasts the entity event responsible for playing the respective sound at the beginning of a conversion. This is not always wanted by developers when modifying already converting zombies in particular. This commit expands the ZombieVillager interface with another overload of the setConversionTime method that also takes a simple toggle flag indicating whether or not the entity event should be published to the world.
This commit is contained in:
parent
913ca9381e
commit
c908ebcbcb
2 changed files with 79 additions and 0 deletions
|
@ -701,3 +701,30 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ boolean isInterested();
|
+ boolean isInterested();
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
}
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/entity/ZombieVillager.java b/src/main/java/org/bukkit/entity/ZombieVillager.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/entity/ZombieVillager.java
|
||||||
|
+++ b/src/main/java/org/bukkit/entity/ZombieVillager.java
|
||||||
|
@@ -0,0 +0,0 @@ public interface ZombieVillager extends Zombie {
|
||||||
|
* @param conversionPlayer the player
|
||||||
|
*/
|
||||||
|
void setConversionPlayer(@Nullable OfflinePlayer conversionPlayer);
|
||||||
|
+
|
||||||
|
+ // Paper start - missing entity behaviour api - converting without entity event
|
||||||
|
+ /**
|
||||||
|
+ * Sets the amount of ticks until this entity will be converted to a
|
||||||
|
+ * Villager as a result of being cured.
|
||||||
|
+ * <p>
|
||||||
|
+ * When this reaches 0, the entity will be converted. A value of less than 0
|
||||||
|
+ * will stop the current conversion process without converting the current
|
||||||
|
+ * entity.
|
||||||
|
+ *
|
||||||
|
+ * @param time new conversion time
|
||||||
|
+ * @param broadcastEntityEvent whether this conversion time mutation should broadcast the
|
||||||
|
+ * org.bukkit.{@link org.bukkit.EntityEffect#ZOMBIE_TRANSFORM} entity event to the
|
||||||
|
+ * world. If false, no entity event is published, preventing for example the
|
||||||
|
+ * org.bukkit.{@link org.bukkit.Sound#ENTITY_ZOMBIE_VILLAGER_CURE} from playing.
|
||||||
|
+ */
|
||||||
|
+ void setConversionTime(int time, boolean broadcastEntityEvent);
|
||||||
|
+ // Paper stop - missing entity behaviour api - converting without entity event
|
||||||
|
}
|
||||||
|
|
|
@ -118,6 +118,32 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@Override
|
@Override
|
||||||
protected boolean shouldDespawnInPeaceful() {
|
protected boolean shouldDespawnInPeaceful() {
|
||||||
return true;
|
return true;
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/entity/monster/ZombieVillager.java b/src/main/java/net/minecraft/world/entity/monster/ZombieVillager.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/entity/monster/ZombieVillager.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/entity/monster/ZombieVillager.java
|
||||||
|
@@ -0,0 +0,0 @@ public class ZombieVillager extends Zombie implements VillagerDataHolder {
|
||||||
|
}
|
||||||
|
|
||||||
|
public void startConverting(@Nullable UUID uuid, int delay) {
|
||||||
|
+ // Paper start - missing entity behaviour api - converting without entity event
|
||||||
|
+ this.startConverting(uuid, delay, true);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public void startConverting(@Nullable UUID uuid, int delay, boolean broadcastEntityEvent) {
|
||||||
|
+ // Paper end - missing entity behaviour api - converting without entity event
|
||||||
|
this.conversionStarter = uuid;
|
||||||
|
this.villagerConversionTime = delay;
|
||||||
|
this.getEntityData().set(ZombieVillager.DATA_CONVERTING_ID, true);
|
||||||
|
@@ -0,0 +0,0 @@ public class ZombieVillager extends Zombie implements VillagerDataHolder {
|
||||||
|
this.removeEffect(MobEffects.WEAKNESS, org.bukkit.event.entity.EntityPotionEffectEvent.Cause.CONVERSION);
|
||||||
|
this.addEffect(new MobEffectInstance(MobEffects.DAMAGE_BOOST, delay, Math.min(this.level.getDifficulty().getId() - 1, 0)), org.bukkit.event.entity.EntityPotionEffectEvent.Cause.CONVERSION);
|
||||||
|
// CraftBukkit end
|
||||||
|
- this.level.broadcastEntityEvent(this, (byte) 16);
|
||||||
|
+ if (broadcastEntityEvent) this.level.broadcastEntityEvent(this, (byte) 16); // Paper - missing entity behaviour api - converting without entity event
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
diff --git a/src/main/java/net/minecraft/world/entity/projectile/ThrownTrident.java b/src/main/java/net/minecraft/world/entity/projectile/ThrownTrident.java
|
diff --git a/src/main/java/net/minecraft/world/entity/projectile/ThrownTrident.java b/src/main/java/net/minecraft/world/entity/projectile/ThrownTrident.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/world/entity/projectile/ThrownTrident.java
|
--- a/src/main/java/net/minecraft/world/entity/projectile/ThrownTrident.java
|
||||||
|
@ -563,6 +589,32 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
// Paper end
|
// Paper end
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftVillagerZombie.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftVillagerZombie.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftVillagerZombie.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftVillagerZombie.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftVillagerZombie extends CraftZombie implements ZombieVillager {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setConversionTime(int time) {
|
||||||
|
+ // Paper start - missing entity behaviour api - converting without entity event
|
||||||
|
+ this.setConversionTime(time, true);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public void setConversionTime(int time, boolean broadcastEntityEvent) {
|
||||||
|
+ // Paper stop - missing entity behaviour api - converting without entity event
|
||||||
|
if (time < 0) {
|
||||||
|
this.getHandle().villagerConversionTime = -1;
|
||||||
|
this.getHandle().getEntityData().set(net.minecraft.world.entity.monster.ZombieVillager.DATA_CONVERTING_ID, false);
|
||||||
|
this.getHandle().conversionStarter = null;
|
||||||
|
this.getHandle().removeEffect(MobEffects.DAMAGE_BOOST, org.bukkit.event.entity.EntityPotionEffectEvent.Cause.CONVERSION);
|
||||||
|
} else {
|
||||||
|
- this.getHandle().startConverting((UUID) null, time);
|
||||||
|
+ this.getHandle().startConverting((UUID) null, time, broadcastEntityEvent); // Paper - missing entity behaviour api - converting without entity event
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftWither.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftWither.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftWither.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftWither.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftWither.java
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftWither.java
|
||||||
|
|
Loading…
Reference in a new issue