26734e83b0
* Updated Upstream (Bukkit/CraftBukkit/Spigot) 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: 8085edde SPIGOT-6918: Add SpawnCategory API and configurations for Axolotls 04c7e13c PR-719: Add Player Profile API 71564210 SPIGOT-6910: Add BlockDamageAbortEvent CraftBukkit Changes: febaa1c6 SPIGOT-6918: Add SpawnCategory API and configurations for Axolotls 9dafd109 Don't send updates over large distances bdac46b0 SPIGOT-6782: EntityPortalEvent should not destroy entity when setTo() uses same world as getFrom() 8f361ece PR-1002: Add Player Profile API 911875d4 Increase outdated build delay e5f8a767 SPIGOT-6917: Use main scoreboard for /trigger a672a531 Clean up callBlockDamageEvent 8e1bdeef SPIGOT-6910: Add BlockDamageAbortEvent Spigot Changes: 6edb62f3 Rebuild patches 7fbc6a1e Rebuild patches * Updated Upstream (CraftBukkit) 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 CraftBukkit Changes: de951355 SPIGOT-6927: Fix default value of spawn-limits in Worlds
133 lines
6.4 KiB
Diff
133 lines
6.4 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 95d4785222d732488971e640567668353d6cf96d..bb990265990769eacc99a0ce8b1384888976ec31 100644
|
|
--- a/src/main/java/net/minecraft/world/level/Level.java
|
|
+++ b/src/main/java/net/minecraft/world/level/Level.java
|
|
@@ -987,7 +987,7 @@ 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 e3027cae3674502bdc34fdbd7002980515ffc837..07691d38960add169d24bc830ac7b951bd5afaef 100644
|
|
--- a/src/main/java/net/minecraft/world/level/entity/EntitySection.java
|
|
+++ b/src/main/java/net/minecraft/world/level/entity/EntitySection.java
|
|
@@ -13,6 +13,10 @@ 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;
|
|
@@ -20,10 +24,24 @@ 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);
|
|
}
|
|
|
|
@@ -42,7 +60,7 @@ 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 13df7889b2b5249fb81c54fadf55315a4c515116..74210dc2eef63da7360b1f833bb59b278419fb2b 100644
|
|
--- a/src/main/java/net/minecraft/world/level/entity/EntitySectionStorage.java
|
|
+++ b/src/main/java/net/minecraft/world/level/entity/EntitySectionStorage.java
|
|
@@ -111,13 +111,20 @@ public class EntitySectionStorage<T extends EntityAccess> {
|
|
}
|
|
|
|
public void getEntities(AABB box, Consumer<T> action) {
|
|
+ // Paper start
|
|
+ this.getEntities(box, action, false);
|
|
+ }
|
|
+ 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 9723a0ad61548c8c6c4c5ef20a150d5b17d80afd..da1ad0b2679e392ed81b50c15f012c63cb5c939e 100644
|
|
--- a/src/main/java/net/minecraft/world/level/entity/LevelEntityGetter.java
|
|
+++ b/src/main/java/net/minecraft/world/level/entity/LevelEntityGetter.java
|
|
@@ -17,6 +17,7 @@ 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 d5129c12c79eb6fe6b7e5f8eed4d24226423f5fd..3b13f6ea36a3bfecabe09221eb5c48dddab119db 100644
|
|
--- a/src/main/java/net/minecraft/world/level/entity/LevelEntityGetterAdapter.java
|
|
+++ b/src/main/java/net/minecraft/world/level/entity/LevelEntityGetterAdapter.java
|
|
@@ -38,7 +38,13 @@ 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
|