2021-04-18 02:13:30 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: JellySquid <jellysquid+atwork@protonmail.com>
|
|
|
|
Date: Sun, 24 Jan 2021 22:55:55 +0100
|
|
|
|
Subject: [PATCH] lithium entity
|
|
|
|
|
|
|
|
Co-authored-by: Hugo Planque <hookwood01@gmail.com>
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/EntityLiving.java b/src/main/java/net/minecraft/world/entity/EntityLiving.java
|
2021-04-22 17:50:26 +02:00
|
|
|
index a057be22f488f76b926c81dc5c63e7f9c3fb54a1..45924c33b2928e25dedaae22d06f2a7a181ead25 100644
|
2021-04-18 02:13:30 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/EntityLiving.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/EntityLiving.java
|
2021-04-22 17:50:26 +02:00
|
|
|
@@ -279,6 +279,9 @@ public abstract class EntityLiving extends Entity {
|
|
|
|
this.bg = this.a(new Dynamic(dynamicopsnbt, dynamicopsnbt.createMap((Map) ImmutableMap.of(dynamicopsnbt.createString("memories"), dynamicopsnbt.emptyMap()))));
|
2021-04-18 02:13:30 +02:00
|
|
|
}
|
2021-04-22 17:50:26 +02:00
|
|
|
|
2021-04-18 02:13:30 +02:00
|
|
|
+ private IBlockData lastStateAtFeet = null;
|
|
|
|
+
|
|
|
|
+ private long lastPos = Long.MIN_VALUE;
|
|
|
|
protected void initAttributes() {} // Purpur
|
|
|
|
|
2021-04-22 17:50:26 +02:00
|
|
|
public BehaviorController<?> getBehaviorController() {
|
|
|
|
@@ -355,6 +358,10 @@ public abstract class EntityLiving extends Entity {
|
2021-04-18 02:13:30 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public void entityBaseTick() {
|
|
|
|
+ // Yatopia start - port lithium
|
|
|
|
+ this.lastStateAtFeet = null;
|
|
|
|
+ this.lastPos = Long.MIN_VALUE;
|
|
|
|
+ // Yatopia end
|
|
|
|
this.ar = this.as;
|
|
|
|
if (this.justCreated) {
|
|
|
|
this.getBedPosition().ifPresent(this::a);
|
2021-04-22 17:50:26 +02:00
|
|
|
@@ -1775,7 +1782,24 @@ public abstract class EntityLiving extends Entity {
|
2021-04-21 18:12:08 +02:00
|
|
|
}
|
2021-04-18 02:13:30 +02:00
|
|
|
|
|
|
|
public IBlockData ds() {
|
2021-04-21 18:12:08 +02:00
|
|
|
- return this.world.getBlockStateIfLoaded(this.getChunkCoordinates()); // Yatopia
|
2021-04-18 02:13:30 +02:00
|
|
|
+ // Yatopia start - port lithium
|
|
|
|
+ int x = MathHelper.floor(this.locX());
|
|
|
|
+ int y = MathHelper.floor(this.locY());
|
|
|
|
+ int z = MathHelper.floor(this.locZ());
|
|
|
|
+
|
|
|
|
+ long pos = getChunkCoordinates().asLong();
|
|
|
|
+
|
|
|
|
+ if (this.lastPos == pos) {
|
|
|
|
+ return this.lastStateAtFeet;
|
|
|
|
+ }
|
|
|
|
+
|
2021-04-21 18:12:08 +02:00
|
|
|
+ IBlockData state = this.world.getBlockStateIfLoaded(this.getChunkCoordinates());
|
2021-04-18 02:13:30 +02:00
|
|
|
+
|
|
|
|
+ this.lastPos = pos;
|
|
|
|
+ this.lastStateAtFeet = state;
|
|
|
|
+
|
|
|
|
+ return state;
|
|
|
|
+ // Yatopia end
|
|
|
|
}
|
|
|
|
|
|
|
|
private boolean c(BlockPosition blockposition, IBlockData iblockdata) {
|