From 1433afc6b543faf91b1700a5bfb1094af8cfc676 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 7a40f0864677e54c3a0eca6dcb9a115864edfbbd..1d5d87e61946c674f61541455cf54018bfca1ecb 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 by; private BlockPosition bz; private float bA; - + public int ticksSinceLastInteraction; // Purpur public boolean aware = true; // CraftBukkit protected EntityInsentient(EntityTypes entitytypes, World world) { @@ -205,6 +205,7 @@ public abstract class EntityInsentient extends EntityLiving { entityliving = null; } } + if (entityliving instanceof EntityPlayer) this.ticksSinceLastInteraction = 0; // Purpur this.goalTarget = entityliving; return true; // CraftBukkit end @@ -248,10 +249,35 @@ public abstract class EntityInsentient extends EntityLiving { this.m(); 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.m(); @@ -425,6 +451,7 @@ public abstract class EntityInsentient extends EntityLiving { } nbttagcompound.setBoolean("Bukkit.Aware", this.aware); // CraftBukkit + nbttagcompound.setInt("Purpur.ticksSinceLastInteraction", ticksSinceLastInteraction); // Purpur } @Override @@ -495,6 +522,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 @@ -1544,7 +1576,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 bd206f1810283b409ea69cbfe471eadbef4b8ec2..a57588acf06802fbcf086dd1533bf9619d49e22f 100644 --- a/src/main/java/net/minecraft/server/PlayerConnection.java +++ b/src/main/java/net/minecraft/server/PlayerConnection.java @@ -2214,6 +2214,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 91d7d123be1f5ffa12710bab56788b330dc3ba37..2f326f88257f5a45deee872865211d15fc67fac6 100644 --- a/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java +++ b/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java @@ -103,6 +103,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() {