lithium patches
This commit is contained in:
173
patches/server/0111-lithium-cache-iterate-outwards.patch
Normal file
173
patches/server/0111-lithium-cache-iterate-outwards.patch
Normal file
@@ -0,0 +1,173 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: 2No2Name <2No2Name@web.de>
|
||||
Date: Thu, 13 Jan 2022 15:38:29 -0500
|
||||
Subject: [PATCH] lithium: cache iterate outwards
|
||||
|
||||
Original code by CaffeineMC, licensed under GNU Lesser General Public License v3.0
|
||||
You can find the original code on https://github.com/CaffeineMC/lithium-fabric (Yarn mappings)
|
||||
|
||||
diff --git a/src/main/java/me/jellysquid/mods/lithium/common/cached_blockpos_iteration/IterateOutwardsCache.java b/src/main/java/me/jellysquid/mods/lithium/common/cached_blockpos_iteration/IterateOutwardsCache.java
|
||||
new file mode 100644
|
||||
index 0000000000000000000000000000000000000000..5e805a83d232b32450c18bb5d525a69dd9c9f67f
|
||||
--- /dev/null
|
||||
+++ b/src/main/java/me/jellysquid/mods/lithium/common/cached_blockpos_iteration/IterateOutwardsCache.java
|
||||
@@ -0,0 +1,71 @@
|
||||
+package me.jellysquid.mods.lithium.common.cached_blockpos_iteration;
|
||||
+
|
||||
+import it.unimi.dsi.fastutil.longs.LongArrayList;
|
||||
+import it.unimi.dsi.fastutil.longs.LongList;
|
||||
+import java.util.Iterator;
|
||||
+import java.util.Random;
|
||||
+import java.util.concurrent.ConcurrentHashMap;
|
||||
+import net.minecraft.core.BlockPos;
|
||||
+
|
||||
+/**
|
||||
+ * @author 2No2Name, original implemenation by SuperCoder7979 and Gegy1000
|
||||
+ */
|
||||
+public class IterateOutwardsCache {
|
||||
+ //POS_ZERO must not be replaced with BlockPos.ORIGIN, otherwise iterateOutwards at BlockPos.ORIGIN will not use the cache
|
||||
+ public static final BlockPos POS_ZERO = new BlockPos(0,0,0);
|
||||
+
|
||||
+
|
||||
+ private final ConcurrentHashMap<Long, LongArrayList> table;
|
||||
+ private final int capacity;
|
||||
+ private final Random random;
|
||||
+
|
||||
+ public IterateOutwardsCache(int capacity) {
|
||||
+ this.capacity = capacity;
|
||||
+ this.table = new ConcurrentHashMap<>(31);
|
||||
+ this.random = new Random();
|
||||
+ }
|
||||
+
|
||||
+ private void fillPositionsWithIterateOutwards(LongList entry, int xRange, int yRange, int zRange) {
|
||||
+ // Add all positions to the cached list
|
||||
+ for (BlockPos pos : BlockPos.withinManhattan(POS_ZERO, xRange, yRange, zRange)) {
|
||||
+ entry.add(pos.asLong());
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ public LongList getOrCompute(int xRange, int yRange, int zRange) {
|
||||
+ long key = BlockPos.asLong(xRange, yRange, zRange);
|
||||
+
|
||||
+ LongArrayList entry = this.table.get(key);
|
||||
+ if (entry != null) {
|
||||
+ return entry;
|
||||
+ }
|
||||
+
|
||||
+ // Cache miss: compute and store
|
||||
+ entry = new LongArrayList(128);
|
||||
+
|
||||
+ this.fillPositionsWithIterateOutwards(entry, xRange, yRange, zRange);
|
||||
+
|
||||
+ //decrease the array size, as of now it won't be modified anymore anyways
|
||||
+ entry.trim();
|
||||
+
|
||||
+ //this might overwrite an entry as the same entry could have been computed and added during this thread's computation
|
||||
+ //we do not use computeIfAbsent, as it can delay other threads for too long
|
||||
+ Object previousEntry = this.table.put(key, entry);
|
||||
+
|
||||
+
|
||||
+ if (previousEntry == null && this.table.size() > this.capacity) {
|
||||
+ //prevent a memory leak by randomly removing about 1/8th of the elements when the exceed the desired capacity is exceeded
|
||||
+ final Iterator<Long> iterator = this.table.keySet().iterator();
|
||||
+ //prevent an unlikely infinite loop caused by another thread filling the table concurrently using counting
|
||||
+ for (int i = -this.capacity; iterator.hasNext() && i < 5; i++) {
|
||||
+ Long key2 = iterator.next();
|
||||
+ //random is not threadsafe, but it doesn't matter here, because we don't need quality random numbers
|
||||
+ if (this.random.nextInt(8) == 0 && key2 != key) {
|
||||
+ iterator.remove();
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ return entry;
|
||||
+ }
|
||||
+}
|
||||
diff --git a/src/main/java/me/jellysquid/mods/lithium/common/cached_blockpos_iteration/LongList2BlockPosMutableIterable.java b/src/main/java/me/jellysquid/mods/lithium/common/cached_blockpos_iteration/LongList2BlockPosMutableIterable.java
|
||||
new file mode 100644
|
||||
index 0000000000000000000000000000000000000000..9e79db3aff1a351a8cdf8e55cbcbc26b3a389009
|
||||
--- /dev/null
|
||||
+++ b/src/main/java/me/jellysquid/mods/lithium/common/cached_blockpos_iteration/LongList2BlockPosMutableIterable.java
|
||||
@@ -0,0 +1,46 @@
|
||||
+package me.jellysquid.mods.lithium.common.cached_blockpos_iteration;
|
||||
+
|
||||
+import it.unimi.dsi.fastutil.longs.LongIterator;
|
||||
+import it.unimi.dsi.fastutil.longs.LongList;
|
||||
+import java.util.Iterator;
|
||||
+import net.minecraft.core.BlockPos;
|
||||
+
|
||||
+/**
|
||||
+ * @author 2No2Name
|
||||
+ */
|
||||
+public class LongList2BlockPosMutableIterable implements Iterable<BlockPos> {
|
||||
+
|
||||
+ private final LongList positions;
|
||||
+ private final int xOffset, yOffset, zOffset;
|
||||
+
|
||||
+ public LongList2BlockPosMutableIterable(BlockPos offset, LongList posList) {
|
||||
+ this.xOffset = offset.getX();
|
||||
+ this.yOffset = offset.getY();
|
||||
+ this.zOffset = offset.getZ();
|
||||
+ this.positions = posList;
|
||||
+ }
|
||||
+
|
||||
+ @Override
|
||||
+ public Iterator<BlockPos> iterator() {
|
||||
+ return new Iterator<BlockPos>() {
|
||||
+
|
||||
+ private final LongIterator it = LongList2BlockPosMutableIterable.this.positions.iterator();
|
||||
+ private final BlockPos.MutableBlockPos pos = new BlockPos.MutableBlockPos();
|
||||
+
|
||||
+ @Override
|
||||
+ public boolean hasNext() {
|
||||
+ return it.hasNext();
|
||||
+ }
|
||||
+
|
||||
+ @Override
|
||||
+ public net.minecraft.core.BlockPos next() {
|
||||
+ long nextPos = this.it.nextLong();
|
||||
+ return this.pos.set(
|
||||
+ LongList2BlockPosMutableIterable.this.xOffset + BlockPos.getX(nextPos),
|
||||
+ LongList2BlockPosMutableIterable.this.yOffset + BlockPos.getY(nextPos),
|
||||
+ LongList2BlockPosMutableIterable.this.zOffset + BlockPos.getZ(nextPos));
|
||||
+ }
|
||||
+ };
|
||||
+ }
|
||||
+
|
||||
+}
|
||||
diff --git a/src/main/java/net/minecraft/core/BlockPos.java b/src/main/java/net/minecraft/core/BlockPos.java
|
||||
index 14610e6144ec144ebbec6fb0945c67bb0ea86795..f8bd0c2b78de2efb19243fc702302eeae25691de 100644
|
||||
--- a/src/main/java/net/minecraft/core/BlockPos.java
|
||||
+++ b/src/main/java/net/minecraft/core/BlockPos.java
|
||||
@@ -18,6 +18,12 @@ import net.minecraft.world.phys.Vec3;
|
||||
import org.apache.commons.lang3.Validate;
|
||||
import org.apache.logging.log4j.LogManager;
|
||||
import org.apache.logging.log4j.Logger;
|
||||
+// JettPack start
|
||||
+import it.unimi.dsi.fastutil.longs.LongList;
|
||||
+import me.jellysquid.mods.lithium.common.cached_blockpos_iteration.IterateOutwardsCache;
|
||||
+import me.jellysquid.mods.lithium.common.cached_blockpos_iteration.LongList2BlockPosMutableIterable;
|
||||
+import static me.jellysquid.mods.lithium.common.cached_blockpos_iteration.IterateOutwardsCache.POS_ZERO;
|
||||
+// JettPack end
|
||||
|
||||
@Immutable
|
||||
public class BlockPos extends Vec3i {
|
||||
@@ -284,7 +290,18 @@ public class BlockPos extends Vec3i {
|
||||
};
|
||||
}
|
||||
|
||||
+ // JettPack start - lithium: cached iterate outwards
|
||||
+ private static final IterateOutwardsCache ITERATE_OUTWARDS_CACHE = new IterateOutwardsCache(50);
|
||||
+ private static final LongList HOGLIN_PIGLIN_CACHE = ITERATE_OUTWARDS_CACHE.getOrCompute(8, 4, 8);
|
||||
+ // JettPack end
|
||||
+
|
||||
public static Iterable<BlockPos> withinManhattan(BlockPos center, int rangeX, int rangeY, int rangeZ) {
|
||||
+ // JettPack start - lithium: cached iterate outwards
|
||||
+ if (center != POS_ZERO) {
|
||||
+ final LongList positions = rangeX == 8 && rangeY == 4 && rangeZ == 8 ? HOGLIN_PIGLIN_CACHE : ITERATE_OUTWARDS_CACHE.getOrCompute(rangeX, rangeY, rangeZ);
|
||||
+ return new LongList2BlockPosMutableIterable(center, positions);
|
||||
+ }
|
||||
+ // JettPack end
|
||||
int i = rangeX + rangeY + rangeZ;
|
||||
// Paper start - rename variables to fix conflict with anonymous class (remap fix)
|
||||
int centerX = center.getX();
|
||||
79
patches/server/0112-lithium-ai.raid.patch
Normal file
79
patches/server/0112-lithium-ai.raid.patch
Normal file
@@ -0,0 +1,79 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: jellysquid3 <jellysquid3@users.noreply.github.com>
|
||||
Date: Tue, 18 Jan 2022 10:37:18 -0500
|
||||
Subject: [PATCH] lithium: ai.raid
|
||||
|
||||
Original code by CaffeineMC, licensed under GNU Lesser General Public License v3.0
|
||||
You can find the original code on https://github.com/CaffeineMC/lithium-fabric (Yarn mappings)
|
||||
|
||||
diff --git a/src/main/java/net/minecraft/world/entity/raid/Raid.java b/src/main/java/net/minecraft/world/entity/raid/Raid.java
|
||||
index eb08620d4f1f1b87bb5418b8df323674bc20cf4c..e3ae4ae1f4c2e4400c3f2ff1f620374867e17227 100644
|
||||
--- a/src/main/java/net/minecraft/world/entity/raid/Raid.java
|
||||
+++ b/src/main/java/net/minecraft/world/entity/raid/Raid.java
|
||||
@@ -269,7 +269,16 @@ public class Raid {
|
||||
this.status = Raid.RaidStatus.STOPPED;
|
||||
}
|
||||
|
||||
+ private boolean isBarDirty; // JettPack
|
||||
public void tick() {
|
||||
+ // JettPack start - lithium: ai.raid
|
||||
+ if (this.isBarDirty) {
|
||||
+ this.raidEvent.setProgress(Mth.clamp(this.getHealthOfLivingRaiders() / this.totalHealth, 0.0F, 1.0F));
|
||||
+
|
||||
+ this.isBarDirty = false;
|
||||
+ }
|
||||
+ // JettPack end
|
||||
+
|
||||
if (!this.isStopped()) {
|
||||
if (this.status == Raid.RaidStatus.ONGOING) {
|
||||
boolean flag = this.active;
|
||||
@@ -625,7 +634,7 @@ public class Raid {
|
||||
}
|
||||
|
||||
public void updateBossbar() {
|
||||
- this.raidEvent.setProgress(Mth.clamp(this.getHealthOfLivingRaiders() / this.totalHealth, 0.0F, 1.0F));
|
||||
+ this.isBarDirty = true; // JettPack - lithium: ai.raid
|
||||
}
|
||||
|
||||
public float getHealthOfLivingRaiders() {
|
||||
diff --git a/src/main/java/net/minecraft/world/entity/raid/Raider.java b/src/main/java/net/minecraft/world/entity/raid/Raider.java
|
||||
index 74a0866513ea04f635089badfd5cde132d2d1355..c6c3e0b25040513fd600b09f505ac259d76e1f4e 100644
|
||||
--- a/src/main/java/net/minecraft/world/entity/raid/Raider.java
|
||||
+++ b/src/main/java/net/minecraft/world/entity/raid/Raider.java
|
||||
@@ -47,8 +47,9 @@ import net.minecraft.world.phys.Vec3;
|
||||
public abstract class Raider extends PatrollingMonster {
|
||||
|
||||
protected static final EntityDataAccessor<Boolean> IS_CELEBRATING = SynchedEntityData.defineId(Raider.class, EntityDataSerializers.BOOLEAN);
|
||||
+ public static final ItemStack CACHED_OMINOUS_BANNER = Raid.getLeaderBannerInstance(); // JettPack - lithium: ai.raid
|
||||
static final Predicate<ItemEntity> ALLOWED_ITEMS = (entityitem) -> {
|
||||
- return !entityitem.hasPickUpDelay() && entityitem.isAlive() && ItemStack.matches(entityitem.getItem(), Raid.getLeaderBannerInstance());
|
||||
+ return !entityitem.hasPickUpDelay() && entityitem.isAlive() && ItemStack.matches(entityitem.getItem(), CACHED_OMINOUS_BANNER); // JettPack - lithium: ai.raid
|
||||
};
|
||||
@Nullable
|
||||
protected Raid raid;
|
||||
@@ -150,7 +151,7 @@ public abstract class Raider extends PatrollingMonster {
|
||||
}
|
||||
}
|
||||
|
||||
- if (!itemstack.isEmpty() && ItemStack.matches(itemstack, Raid.getLeaderBannerInstance()) && entityhuman != null) {
|
||||
+ if (!itemstack.isEmpty() && ItemStack.matches(itemstack, CACHED_OMINOUS_BANNER) && entityhuman != null) { // JettPack - lithium: ai.raid
|
||||
MobEffectInstance mobeffect = entityhuman.getEffect(MobEffects.BAD_OMEN);
|
||||
byte b0 = 1;
|
||||
int i;
|
||||
@@ -305,6 +306,7 @@ public abstract class Raider extends PatrollingMonster {
|
||||
public class ObtainRaidLeaderBannerGoal<T extends Raider> extends Goal {
|
||||
|
||||
private final T mob;
|
||||
+ private static final ItemStack CACHED_OMINOUS_BANNER = Raid.getLeaderBannerInstance(); // JettPack
|
||||
|
||||
public ObtainRaidLeaderBannerGoal(T entityraider) { // CraftBukkit - decompile error
|
||||
this.mob = entityraider;
|
||||
@@ -316,7 +318,7 @@ public abstract class Raider extends PatrollingMonster {
|
||||
if (!this.mob.level.getGameRules().getBoolean(GameRules.RULE_MOBGRIEFING) || !this.mob.canPickUpLoot()) return false; // Paper - respect game and entity rules for picking up items
|
||||
Raid raid = this.mob.getCurrentRaid();
|
||||
|
||||
- if (this.mob.hasActiveRaid() && !this.mob.getCurrentRaid().isOver() && this.mob.canBeLeader() && !ItemStack.matches(this.mob.getItemBySlot(EquipmentSlot.HEAD), Raid.getLeaderBannerInstance())) {
|
||||
+ if (this.mob.hasActiveRaid() && !this.mob.getCurrentRaid().isOver() && this.mob.canBeLeader() && !ItemStack.matches(this.mob.getItemBySlot(EquipmentSlot.HEAD), CACHED_OMINOUS_BANNER)) { // JettPack - lithium: ai.raid
|
||||
Raider entityraider = raid.getLeader(this.mob.getWave());
|
||||
|
||||
if (entityraider == null || !entityraider.isAlive()) {
|
||||
Reference in New Issue
Block a user