From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: William Blake Galbreath Date: Sat, 11 Jul 2020 19:41:34 -0500 Subject: [PATCH] Entity lifespan diff --git a/src/main/java/net/minecraft/server/EntityInsentient.java b/src/main/java/net/minecraft/server/EntityInsentient.java index 2a60f08530..e276a59203 100644 --- a/src/main/java/net/minecraft/server/EntityInsentient.java +++ b/src/main/java/net/minecraft/server/EntityInsentient.java @@ -53,7 +53,7 @@ public abstract class EntityInsentient extends EntityLiving { private NBTTagCompound bF; private BlockPosition bG; private float bH; - + public int ticksSinceLastInteraction; // Purpur public boolean aware = true; // CraftBukkit protected EntityInsentient(EntityTypes entitytypes, World world) { @@ -203,6 +203,7 @@ public abstract class EntityInsentient extends EntityLiving { entityliving = null; } } + if (entityliving instanceof EntityPlayer) this.ticksSinceLastInteraction = 0; // Purpur this.goalTarget = entityliving; return true; // CraftBukkit end @@ -246,10 +247,35 @@ public abstract class EntityInsentient extends EntityLiving { this.eJ(); this.F(); } - + incrementTicksSinceLastInteraction(); // Purpur this.world.getMethodProfiler().exit(); } + // Purpur start + private void incrementTicksSinceLastInteraction() { + ++ticksSinceLastInteraction; + if (hasRider()) { + ticksSinceLastInteraction = 0; + return; + } + if (world.purpurConfig.entityLifeSpan <= 0) { + return; // feature disabled + } + if (!isTypeNotPersistent(0) || isPersistent() || isSpecialPersistence() || hasCustomName()) { + return; // mob persistent + } + if (ticksSinceLastInteraction > world.purpurConfig.entityLifeSpan) { + this.dead = true; + } + } + + @Override + public boolean damageEntity(DamageSource damagesource, float f) { + if (damagesource.getEntity() instanceof EntityPlayer) this.ticksSinceLastInteraction = 0; // Purpur + return super.damageEntity(damagesource, f); + } + // Purpur end + @Override protected void c(DamageSource damagesource) { this.eJ(); @@ -423,6 +449,7 @@ public abstract class EntityInsentient extends EntityLiving { } nbttagcompound.setBoolean("Bukkit.Aware", this.aware); // CraftBukkit + nbttagcompound.setInt("Purpur.ticksSinceLastInteraction", ticksSinceLastInteraction); // Purpur } @Override @@ -493,6 +520,11 @@ public abstract class EntityInsentient extends EntityLiving { this.aware = nbttagcompound.getBoolean("Bukkit.Aware"); } // CraftBukkit end + // Purpur start + if (nbttagcompound.hasKey("Purpur.ticksSinceLastInteraction")) { + ticksSinceLastInteraction = nbttagcompound.getInt("Purpur.ticksSinceLastInteraction"); + } + // Purpur end } @Override @@ -1511,7 +1543,7 @@ public abstract class EntityInsentient extends EntityLiving { this.a((EntityLiving) this, entity); this.z(entity); } - + if (entity instanceof EntityPlayer) this.ticksSinceLastInteraction = 0; // Purpur return flag; } diff --git a/src/main/java/net/minecraft/server/PlayerConnection.java b/src/main/java/net/minecraft/server/PlayerConnection.java index 0f1b0065d6..194bb355ca 100644 --- a/src/main/java/net/minecraft/server/PlayerConnection.java +++ b/src/main/java/net/minecraft/server/PlayerConnection.java @@ -2133,6 +2133,7 @@ public class PlayerConnection implements PacketListenerPlayIn { boolean triggerLeashUpdate = itemInHand != null && itemInHand.getItem() == Items.LEAD && entity instanceof EntityInsentient; Item origItem = this.player.inventory.getItemInHand() == null ? null : this.player.inventory.getItemInHand().getItem(); PlayerInteractEntityEvent event; + if (entity instanceof EntityInsentient) ((EntityInsentient) entity).ticksSinceLastInteraction = 0; // Purpur if (packetplayinuseentity.b() == PacketPlayInUseEntity.EnumEntityUseAction.INTERACT) { event = new PlayerInteractEntityEvent((Player) this.getPlayer(), entity.getBukkitEntity(), (packetplayinuseentity.c() == EnumHand.OFF_HAND) ? EquipmentSlot.OFF_HAND : EquipmentSlot.HAND); } else { diff --git a/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java b/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java index 2f5bc77e03..4e8a6992ab 100644 --- a/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java +++ b/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java @@ -101,6 +101,11 @@ public class PurpurWorldConfig { } } + public int entityLifeSpan = 0; + private void entitySettings() { + entityLifeSpan = getInt("gameplay-mechanics.entity-lifespan", entityLifeSpan); + } + public List itemImmuneToExplosion = new ArrayList<>(); public List itemImmuneToFire = new ArrayList<>(); private void itemSettings() {