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/network/PlayerConnection.java b/src/main/java/net/minecraft/server/network/PlayerConnection.java index 611989cd519a5c695d1369b0e74159925c55b726..f92e412d7f49c620699274ecf9ed085c5af53ab8 100644 --- a/src/main/java/net/minecraft/server/network/PlayerConnection.java +++ b/src/main/java/net/minecraft/server/network/PlayerConnection.java @@ -2390,6 +2390,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/minecraft/world/entity/EntityInsentient.java b/src/main/java/net/minecraft/world/entity/EntityInsentient.java index 5a9a658c56f1d39bcbcabc0415c1c3f7d96cfab7..6ea0fc81efe976c2b33cc12de175b357323b9cfd 100644 --- a/src/main/java/net/minecraft/world/entity/EntityInsentient.java +++ b/src/main/java/net/minecraft/world/entity/EntityInsentient.java @@ -124,7 +124,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) { @@ -276,6 +276,7 @@ public abstract class EntityInsentient extends EntityLiving { entityliving = null; } } + if (entityliving instanceof EntityPlayer) this.ticksSinceLastInteraction = 0; // Purpur this.goalTarget = entityliving; return true; // CraftBukkit end @@ -320,10 +321,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(); @@ -497,6 +523,7 @@ public abstract class EntityInsentient extends EntityLiving { } nbttagcompound.setBoolean("Bukkit.Aware", this.aware); // CraftBukkit + nbttagcompound.setInt("Purpur.ticksSinceLastInteraction", ticksSinceLastInteraction); // Purpur } @Override @@ -567,6 +594,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 @@ -1620,7 +1652,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/pl3x/purpur/PurpurWorldConfig.java b/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java index 9d7f7fc586200206ff87dfa463479150ed8cd5f1..fa003079da19ee63a02045d57ea3d6cf64578ebd 100644 --- a/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java +++ b/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java @@ -137,6 +137,11 @@ public class PurpurWorldConfig { } } + public int entityLifeSpan = 0; + private void entitySettings() { + entityLifeSpan = getInt("gameplay-mechanics.entity-lifespan", entityLifeSpan); + } + public List itemImmuneToCactus = new ArrayList<>(); public List itemImmuneToExplosion = new ArrayList<>(); public List itemImmuneToFire = new ArrayList<>();