2018-08-15 10:26:51 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Riley Park <rileysebastianpark@gmail.com>
|
|
|
|
Date: Wed, 15 Aug 2018 01:26:09 -0700
|
|
|
|
Subject: [PATCH] Allow disabling armour stand ticking
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
2019-07-20 06:01:24 +02:00
|
|
|
index 09607fb447..5832c3e868 100644
|
2018-08-15 10:26:51 +02:00
|
|
|
--- a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
|
|
|
@@ -0,0 +0,0 @@ public class PaperWorldConfig {
|
2019-05-05 04:23:25 +02:00
|
|
|
log("Bed Search Radius: " + bedSearchRadius);
|
2018-08-26 20:11:49 +02:00
|
|
|
}
|
2018-08-15 10:26:51 +02:00
|
|
|
}
|
|
|
|
+
|
|
|
|
+ public boolean armorStandTick = true;
|
|
|
|
+ private void armorStandTick() {
|
|
|
|
+ this.armorStandTick = this.getBoolean("armor-stands-tick", this.armorStandTick);
|
|
|
|
+ log("ArmorStand ticking is " + (this.armorStandTick ? "enabled" : "disabled") + " by default");
|
|
|
|
+ }
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/EntityArmorStand.java b/src/main/java/net/minecraft/server/EntityArmorStand.java
|
2019-07-20 06:01:24 +02:00
|
|
|
index 961e284712..b71d061a37 100644
|
2018-08-15 10:26:51 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/EntityArmorStand.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/EntityArmorStand.java
|
|
|
|
@@ -0,0 +0,0 @@ public class EntityArmorStand extends EntityLiving {
|
|
|
|
public Vector3f leftLegPose;
|
|
|
|
public Vector3f rightLegPose;
|
|
|
|
public boolean canMove = true; // Paper
|
2018-11-08 02:48:22 +01:00
|
|
|
+ // Paper start - Allow ArmorStands not to tick
|
|
|
|
+ public boolean canTick = true;
|
|
|
|
+ private boolean noTickPoseDirty = false;
|
|
|
|
+ private boolean noTickEquipmentDirty = false;
|
|
|
|
+ // Paper end
|
2018-08-15 10:26:51 +02:00
|
|
|
|
2019-05-05 04:23:25 +02:00
|
|
|
public EntityArmorStand(EntityTypes<? extends EntityArmorStand> entitytypes, World world) {
|
|
|
|
super(entitytypes, world);
|
2018-08-15 10:26:51 +02:00
|
|
|
@@ -0,0 +0,0 @@ public class EntityArmorStand extends EntityLiving {
|
2019-05-05 04:23:25 +02:00
|
|
|
this.rightArmPose = EntityArmorStand.bx;
|
|
|
|
this.leftLegPose = EntityArmorStand.by;
|
|
|
|
this.rightLegPose = EntityArmorStand.bz;
|
2018-08-15 10:26:51 +02:00
|
|
|
+ if (world != null) this.canTick = world.paperConfig.armorStandTick; // Paper - armour stand ticking
|
2019-05-05 04:23:25 +02:00
|
|
|
this.K = 0.0F;
|
2018-08-15 10:26:51 +02:00
|
|
|
}
|
2019-05-05 04:23:25 +02:00
|
|
|
|
2018-11-08 02:48:22 +01:00
|
|
|
@@ -0,0 +0,0 @@ public class EntityArmorStand extends EntityLiving {
|
2019-05-28 01:01:45 +02:00
|
|
|
this.armorItems.set(enumitemslot.b(), itemstack);
|
2018-11-08 02:48:22 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
+ this.noTickEquipmentDirty = true; // Paper - Allow equipment to be updated even when tick disabled
|
|
|
|
}
|
|
|
|
|
2019-05-05 04:23:25 +02:00
|
|
|
@Override
|
2018-11-28 00:14:57 +01:00
|
|
|
@@ -0,0 +0,0 @@ public class EntityArmorStand extends EntityLiving {
|
|
|
|
}
|
|
|
|
|
2019-05-05 04:23:25 +02:00
|
|
|
nbttagcompound.set("Pose", this.B());
|
2018-11-28 00:14:57 +01:00
|
|
|
+ nbttagcompound.setBoolean("Paper.CanTick", this.canTick); // Paper - persist no tick setting
|
|
|
|
}
|
|
|
|
|
2019-05-05 04:23:25 +02:00
|
|
|
@Override
|
2018-11-28 00:14:57 +01:00
|
|
|
@@ -0,0 +0,0 @@ public class EntityArmorStand extends EntityLiving {
|
2019-05-05 04:23:25 +02:00
|
|
|
this.setBasePlate(nbttagcompound.getBoolean("NoBasePlate"));
|
2018-11-28 00:14:57 +01:00
|
|
|
this.setMarker(nbttagcompound.getBoolean("Marker"));
|
2019-05-05 04:23:25 +02:00
|
|
|
this.noclip = !this.A();
|
2018-11-28 00:14:57 +01:00
|
|
|
+ // Paper start - persist no tick
|
|
|
|
+ if (nbttagcompound.hasKey("Paper.CanTick")) {
|
|
|
|
+ this.canTick = nbttagcompound.getBoolean("Paper.CanTick");
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
NBTTagCompound nbttagcompound1 = nbttagcompound.getCompound("Pose");
|
|
|
|
|
|
|
|
this.g(nbttagcompound1);
|
2018-08-15 10:26:51 +02:00
|
|
|
@@ -0,0 +0,0 @@ public class EntityArmorStand extends EntityLiving {
|
|
|
|
|
2019-05-05 04:23:25 +02:00
|
|
|
@Override
|
2018-08-17 00:11:35 +02:00
|
|
|
public void tick() {
|
2018-11-08 02:48:22 +01:00
|
|
|
+ // Paper start
|
|
|
|
+ if (!this.canTick) {
|
|
|
|
+ if (this.noTickPoseDirty) {
|
2018-11-08 05:23:53 +01:00
|
|
|
+ this.noTickPoseDirty = false;
|
2018-11-08 02:48:22 +01:00
|
|
|
+ this.updatePose();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (this.noTickEquipmentDirty) {
|
|
|
|
+ this.noTickEquipmentDirty = false;
|
|
|
|
+ this.updateEntityEquipment();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+
|
2018-08-17 00:11:35 +02:00
|
|
|
super.tick();
|
2018-11-08 02:48:22 +01:00
|
|
|
+ // Paper start - Split into separate method
|
|
|
|
+ updatePose();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public void updatePose() {
|
|
|
|
+ // Paper end
|
2019-05-05 04:23:25 +02:00
|
|
|
Vector3f vector3f = (Vector3f) this.datawatcher.get(EntityArmorStand.c);
|
2018-08-15 10:26:51 +02:00
|
|
|
|
2018-11-08 02:48:22 +01:00
|
|
|
if (!this.headPose.equals(vector3f)) {
|
|
|
|
@@ -0,0 +0,0 @@ public class EntityArmorStand extends EntityLiving {
|
|
|
|
public void setHeadPose(Vector3f vector3f) {
|
|
|
|
this.headPose = vector3f;
|
2019-05-05 04:23:25 +02:00
|
|
|
this.datawatcher.set(EntityArmorStand.c, vector3f);
|
2018-11-08 02:48:22 +01:00
|
|
|
+ this.noTickPoseDirty = true; // Paper - Allow updates when not ticking
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setBodyPose(Vector3f vector3f) {
|
|
|
|
this.bodyPose = vector3f;
|
2019-05-05 04:23:25 +02:00
|
|
|
this.datawatcher.set(EntityArmorStand.d, vector3f);
|
2018-11-08 02:48:22 +01:00
|
|
|
+ this.noTickPoseDirty = true; // Paper - Allow updates when not ticking
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setLeftArmPose(Vector3f vector3f) {
|
|
|
|
this.leftArmPose = vector3f;
|
2019-05-05 04:23:25 +02:00
|
|
|
this.datawatcher.set(EntityArmorStand.e, vector3f);
|
2018-11-08 02:48:22 +01:00
|
|
|
+ this.noTickPoseDirty = true; // Paper - Allow updates when not ticking
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setRightArmPose(Vector3f vector3f) {
|
|
|
|
this.rightArmPose = vector3f;
|
2019-05-05 04:23:25 +02:00
|
|
|
this.datawatcher.set(EntityArmorStand.f, vector3f);
|
2018-11-08 02:48:22 +01:00
|
|
|
+ this.noTickPoseDirty = true; // Paper - Allow updates when not ticking
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setLeftLegPose(Vector3f vector3f) {
|
|
|
|
this.leftLegPose = vector3f;
|
2019-05-05 04:23:25 +02:00
|
|
|
this.datawatcher.set(EntityArmorStand.g, vector3f);
|
2018-11-08 02:48:22 +01:00
|
|
|
+ this.noTickPoseDirty = true; // Paper - Allow updates when not ticking
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setRightLegPose(Vector3f vector3f) {
|
|
|
|
this.rightLegPose = vector3f;
|
2019-05-05 04:23:25 +02:00
|
|
|
this.datawatcher.set(EntityArmorStand.bs, vector3f);
|
2018-11-08 02:48:22 +01:00
|
|
|
+ this.noTickPoseDirty = true; // Paper - Allow updates when not ticking
|
|
|
|
}
|
|
|
|
|
|
|
|
public Vector3f r() {
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/EntityLiving.java b/src/main/java/net/minecraft/server/EntityLiving.java
|
2019-07-20 06:01:24 +02:00
|
|
|
index b29e0c5d35..2cbcd1e17b 100644
|
2018-11-08 02:48:22 +01:00
|
|
|
--- a/src/main/java/net/minecraft/server/EntityLiving.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/EntityLiving.java
|
|
|
|
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
- EnumItemSlot[] aenumitemslot = EnumItemSlot.values();
|
|
|
|
- int j = aenumitemslot.length;
|
|
|
|
-
|
|
|
|
- for (int k = 0; k < j; ++k) {
|
|
|
|
- EnumItemSlot enumitemslot = aenumitemslot[k];
|
|
|
|
- ItemStack itemstack;
|
|
|
|
-
|
|
|
|
- switch (enumitemslot.a()) {
|
2019-05-28 01:01:45 +02:00
|
|
|
- case HAND:
|
|
|
|
- itemstack = (ItemStack) this.bw.get(enumitemslot.b());
|
|
|
|
- break;
|
|
|
|
- case ARMOR:
|
|
|
|
- itemstack = (ItemStack) this.bx.get(enumitemslot.b());
|
|
|
|
- break;
|
|
|
|
- default:
|
|
|
|
- continue;
|
2018-11-08 02:48:22 +01:00
|
|
|
- }
|
|
|
|
-
|
|
|
|
- ItemStack itemstack1 = this.getEquipment(enumitemslot);
|
|
|
|
-
|
|
|
|
- if (!ItemStack.matches(itemstack1, itemstack)) {
|
|
|
|
- // Paper start - PlayerArmorChangeEvent
|
2019-03-03 21:21:51 +01:00
|
|
|
- if (this instanceof EntityPlayer && enumitemslot.getType() == EnumItemSlot.Function.ARMOR) {
|
2018-11-08 02:48:22 +01:00
|
|
|
- final org.bukkit.inventory.ItemStack oldItem = CraftItemStack.asBukkitCopy(itemstack);
|
|
|
|
- final org.bukkit.inventory.ItemStack newItem = CraftItemStack.asBukkitCopy(itemstack1);
|
|
|
|
- new PlayerArmorChangeEvent((Player) this.getBukkitEntity(), PlayerArmorChangeEvent.SlotType.valueOf(enumitemslot.name()), oldItem, newItem).callEvent();
|
|
|
|
- }
|
|
|
|
- // Paper end
|
2019-05-05 04:23:25 +02:00
|
|
|
- ((WorldServer) this.world).getChunkProvider().broadcast(this, new PacketPlayOutEntityEquipment(this.getId(), enumitemslot, itemstack1));
|
2018-11-08 02:48:22 +01:00
|
|
|
- if (!itemstack.isEmpty()) {
|
|
|
|
- this.getAttributeMap().a(itemstack.a(enumitemslot));
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if (!itemstack1.isEmpty()) {
|
|
|
|
- this.getAttributeMap().b(itemstack1.a(enumitemslot));
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- switch (enumitemslot.a()) {
|
2019-05-28 01:01:45 +02:00
|
|
|
- case HAND:
|
|
|
|
- this.bw.set(enumitemslot.b(), itemstack1.isEmpty() ? ItemStack.a : itemstack1.cloneItemStack());
|
|
|
|
- break;
|
|
|
|
- case ARMOR:
|
|
|
|
- this.bx.set(enumitemslot.b(), itemstack1.isEmpty() ? ItemStack.a : itemstack1.cloneItemStack());
|
2018-11-08 02:48:22 +01:00
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
+ updateEntityEquipment(); // Paper - split into own method
|
|
|
|
|
|
|
|
if (this.ticksLived % 20 == 0) {
|
|
|
|
this.getCombatTracker().g();
|
|
|
|
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start - split into own method from above
|
|
|
|
+ public void updateEntityEquipment() {
|
2018-12-08 11:09:55 +01:00
|
|
|
+ EnumItemSlot[] aenumitemslot = EnumItemSlot.values();
|
|
|
|
+ int j = aenumitemslot.length;
|
|
|
|
+
|
|
|
|
+ for (int k = 0; k < j; ++k) {
|
|
|
|
+ EnumItemSlot enumitemslot = aenumitemslot[k];
|
2018-11-08 02:48:22 +01:00
|
|
|
+ ItemStack itemstack;
|
|
|
|
+
|
|
|
|
+ switch (enumitemslot.a()) {
|
|
|
|
+ case HAND:
|
2019-05-05 04:23:25 +02:00
|
|
|
+ itemstack = (ItemStack) this.bw.get(enumitemslot.b());
|
2018-11-08 02:48:22 +01:00
|
|
|
+ break;
|
|
|
|
+ case ARMOR:
|
2019-05-05 04:23:25 +02:00
|
|
|
+ itemstack = (ItemStack) this.bx.get(enumitemslot.b());
|
2018-11-08 02:48:22 +01:00
|
|
|
+ break;
|
|
|
|
+ default:
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ ItemStack itemstack1 = this.getEquipment(enumitemslot);
|
|
|
|
+
|
|
|
|
+ if (!ItemStack.matches(itemstack1, itemstack)) {
|
|
|
|
+ // Paper start - PlayerArmorChangeEvent
|
2019-03-03 21:21:51 +01:00
|
|
|
+ if (this instanceof EntityPlayer && enumitemslot.getType() == EnumItemSlot.Function.ARMOR) {
|
2018-11-08 02:48:22 +01:00
|
|
|
+ final org.bukkit.inventory.ItemStack oldItem = CraftItemStack.asBukkitCopy(itemstack);
|
|
|
|
+ final org.bukkit.inventory.ItemStack newItem = CraftItemStack.asBukkitCopy(itemstack1);
|
|
|
|
+ new PlayerArmorChangeEvent((Player) this.getBukkitEntity(), PlayerArmorChangeEvent.SlotType.valueOf(enumitemslot.name()), oldItem, newItem).callEvent();
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
2019-05-05 04:23:25 +02:00
|
|
|
+ ((WorldServer) this.world).getChunkProvider().broadcast(this, new PacketPlayOutEntityEquipment(this.getId(), enumitemslot, itemstack1));
|
2018-11-08 02:48:22 +01:00
|
|
|
+ if (!itemstack.isEmpty()) {
|
|
|
|
+ this.getAttributeMap().a(itemstack.a(enumitemslot));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (!itemstack1.isEmpty()) {
|
|
|
|
+ this.getAttributeMap().b(itemstack1.a(enumitemslot));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ switch (enumitemslot.a()) {
|
|
|
|
+ case HAND:
|
2019-05-05 04:23:25 +02:00
|
|
|
+ this.bw.set(enumitemslot.b(), itemstack1.isEmpty() ? ItemStack.a : itemstack1.cloneItemStack());
|
2018-11-08 02:48:22 +01:00
|
|
|
+ break;
|
|
|
|
+ case ARMOR:
|
2019-05-05 04:23:25 +02:00
|
|
|
+ this.bx.set(enumitemslot.b(), itemstack1.isEmpty() ? ItemStack.a : itemstack1.cloneItemStack());
|
2018-11-08 02:48:22 +01:00
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
protected float e(float f, float f1) {
|
2019-05-05 04:23:25 +02:00
|
|
|
float f2 = MathHelper.g(f - this.aK);
|
2018-11-08 02:48:22 +01:00
|
|
|
|
2018-08-15 10:26:51 +02:00
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftArmorStand.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftArmorStand.java
|
2019-07-20 06:01:24 +02:00
|
|
|
index 9f5c3b92e3..07ce93f17c 100644
|
2018-08-15 10:26:51 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftArmorStand.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftArmorStand.java
|
|
|
|
@@ -0,0 +0,0 @@ public class CraftArmorStand extends CraftLivingEntity implements ArmorStand {
|
2018-08-17 00:11:35 +02:00
|
|
|
public boolean isSlotDisabled(org.bukkit.inventory.EquipmentSlot slot) {
|
|
|
|
return getHandle().isSlotDisabled(org.bukkit.craftbukkit.CraftEquipmentSlot.getNMS(slot));
|
2018-08-15 10:26:51 +02:00
|
|
|
}
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean canTick() {
|
|
|
|
+ return this.getHandle().canTick;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void setCanTick(final boolean tick) {
|
|
|
|
+ this.getHandle().canTick = tick;
|
|
|
|
+ }
|
2018-08-17 00:11:35 +02:00
|
|
|
// Paper end
|
2018-08-15 10:26:51 +02:00
|
|
|
}
|
|
|
|
--
|