mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-17 06:48:23 +01:00
60caeea54e
Upstream has released updates that appear to apply and compile correctly. This update has not been tested by PaperMC and as with ANY update, please do your own testing Bukkit Changes: d25437bc Update to Minecraft 1.18-pre8 CraftBukkit Changes: 5a39a236 Update to Minecraft 1.18-pre8 Spigot Changes: 7840c2af Update to Minecraft 1.18-pre8
132 lines
6.3 KiB
Diff
132 lines
6.3 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: CullanP <cullanpage@gmail.com>
|
|
Date: Thu, 3 Mar 2016 02:13:38 -0600
|
|
Subject: [PATCH] Avoid hopper searches if there are no items
|
|
|
|
Hoppers searching for items and minecarts is the most expensive part of hopper ticking.
|
|
We keep track of the number of minecarts and items in a chunk.
|
|
If there are no items in the chunk, we skip searching for items.
|
|
If there are no minecarts in the chunk, we skip searching for them.
|
|
|
|
Usually hoppers aren't near items, so we can skip most item searches.
|
|
And since minecart hoppers are used _very_ rarely near we can avoid alot of searching there.
|
|
|
|
Combined, this adds up a lot.
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/level/Level.java b/src/main/java/net/minecraft/world/level/Level.java
|
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
--- a/src/main/java/net/minecraft/world/level/Level.java
|
|
+++ b/src/main/java/net/minecraft/world/level/Level.java
|
|
@@ -0,0 +0,0 @@ public abstract class Level implements LevelAccessor, AutoCloseable {
|
|
}
|
|
}
|
|
|
|
- });
|
|
+ }, predicate == net.minecraft.world.entity.EntitySelector.CONTAINER_ENTITY_SELECTOR); // Paper
|
|
return list;
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/level/entity/EntitySection.java b/src/main/java/net/minecraft/world/level/entity/EntitySection.java
|
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
--- a/src/main/java/net/minecraft/world/level/entity/EntitySection.java
|
|
+++ b/src/main/java/net/minecraft/world/level/entity/EntitySection.java
|
|
@@ -0,0 +0,0 @@ public class EntitySection<T extends EntityAccess> {
|
|
protected static final Logger LOGGER = LogManager.getLogger();
|
|
private final ClassInstanceMultiMap<T> storage;
|
|
private Visibility chunkStatus;
|
|
+ // Paper start - track number of items and minecarts
|
|
+ public int itemCount;
|
|
+ public int inventoryEntityCount;
|
|
+ // Paper end
|
|
|
|
public EntitySection(Class<T> entityClass, Visibility status) {
|
|
this.chunkStatus = status;
|
|
@@ -0,0 +0,0 @@ public class EntitySection<T extends EntityAccess> {
|
|
}
|
|
|
|
public void add(T entity) {
|
|
+ // Paper start
|
|
+ if (entity instanceof net.minecraft.world.entity.item.ItemEntity) {
|
|
+ this.itemCount++;
|
|
+ } else if (entity instanceof net.minecraft.world.Container) {
|
|
+ this.inventoryEntityCount++;
|
|
+ }
|
|
+ // Paper end
|
|
this.storage.add(entity);
|
|
}
|
|
|
|
public boolean remove(T entity) {
|
|
+ // Paper start
|
|
+ if (entity instanceof net.minecraft.world.entity.item.ItemEntity) {
|
|
+ this.itemCount--;
|
|
+ } else if (entity instanceof net.minecraft.world.Container) {
|
|
+ this.inventoryEntityCount--;
|
|
+ }
|
|
+ // Paper end
|
|
return this.storage.remove(entity);
|
|
}
|
|
|
|
@@ -0,0 +0,0 @@ public class EntitySection<T extends EntityAccess> {
|
|
for(T entityAccess : collection) {
|
|
U entityAccess2 = (U)((EntityAccess)type.tryCast(entityAccess));
|
|
if (entityAccess2 != null && entityAccess.getBoundingBox().intersects(box)) {
|
|
- action.accept((T)entityAccess2);
|
|
+ action.accept(entityAccess2); // Paper - decompile fixes
|
|
}
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/level/entity/EntitySectionStorage.java b/src/main/java/net/minecraft/world/level/entity/EntitySectionStorage.java
|
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
--- a/src/main/java/net/minecraft/world/level/entity/EntitySectionStorage.java
|
|
+++ b/src/main/java/net/minecraft/world/level/entity/EntitySectionStorage.java
|
|
@@ -0,0 +0,0 @@ public class EntitySectionStorage<T extends EntityAccess> {
|
|
}
|
|
|
|
public void getEntities(AABB box, Consumer<T> action) {
|
|
+ // Paper start
|
|
+ }
|
|
+ public void getEntities(AABB box, Consumer<T> action, boolean isContainerSearch) {
|
|
+ // Paper end
|
|
this.forEachAccessibleNonEmptySection(box, (section) -> {
|
|
+ if (isContainerSearch && section.inventoryEntityCount <= 0) return; // Paper
|
|
section.getEntities(box, action);
|
|
});
|
|
}
|
|
|
|
public <U extends T> void getEntities(EntityTypeTest<T, U> filter, AABB box, Consumer<U> action) {
|
|
this.forEachAccessibleNonEmptySection(box, (section) -> {
|
|
+ if (filter.getBaseClass() == net.minecraft.world.entity.item.ItemEntity.class && section.itemCount <= 0) return; // Paper
|
|
section.getEntities(filter, box, action);
|
|
});
|
|
}
|
|
diff --git a/src/main/java/net/minecraft/world/level/entity/LevelEntityGetter.java b/src/main/java/net/minecraft/world/level/entity/LevelEntityGetter.java
|
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
--- a/src/main/java/net/minecraft/world/level/entity/LevelEntityGetter.java
|
|
+++ b/src/main/java/net/minecraft/world/level/entity/LevelEntityGetter.java
|
|
@@ -0,0 +0,0 @@ public interface LevelEntityGetter<T extends EntityAccess> {
|
|
<U extends T> void get(EntityTypeTest<T, U> filter, Consumer<U> action);
|
|
|
|
void get(AABB box, Consumer<T> action);
|
|
+ void get(AABB box, Consumer<T> action, boolean isContainerSearch); // Paper
|
|
|
|
<U extends T> void get(EntityTypeTest<T, U> filter, AABB box, Consumer<U> action);
|
|
}
|
|
diff --git a/src/main/java/net/minecraft/world/level/entity/LevelEntityGetterAdapter.java b/src/main/java/net/minecraft/world/level/entity/LevelEntityGetterAdapter.java
|
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
--- a/src/main/java/net/minecraft/world/level/entity/LevelEntityGetterAdapter.java
|
|
+++ b/src/main/java/net/minecraft/world/level/entity/LevelEntityGetterAdapter.java
|
|
@@ -0,0 +0,0 @@ public class LevelEntityGetterAdapter<T extends EntityAccess> implements LevelEn
|
|
|
|
@Override
|
|
public void get(AABB box, Consumer<T> action) {
|
|
- this.sectionStorage.getEntities(box, action);
|
|
+ // Paper start
|
|
+ this.get(box, action, false);
|
|
+ }
|
|
+ @Override
|
|
+ public void get(AABB box, Consumer<T> action, boolean isContainerSearch) {
|
|
+ this.sectionStorage.getEntities(box, action, isContainerSearch);
|
|
+ // Paper end
|
|
}
|
|
|
|
@Override
|