geforkt von Mirrors/Paper
Iterate over entity array copy for entity scheduler
Dieser Commit ist enthalten in:
Ursprung
9696b46122
Commit
279c17fcdf
@ -1130,15 +1130,17 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
MinecraftTimings.bukkitSchedulerTimer.stopTiming(); // Spigot // Paper
|
MinecraftTimings.bukkitSchedulerTimer.stopTiming(); // Spigot // Paper
|
||||||
+ // Paper start - Folia scheduler API
|
+ // Paper start - Folia scheduler API
|
||||||
+ ((io.papermc.paper.threadedregions.scheduler.FoliaGlobalRegionScheduler) Bukkit.getGlobalRegionScheduler()).tick();
|
+ ((io.papermc.paper.threadedregions.scheduler.FoliaGlobalRegionScheduler) Bukkit.getGlobalRegionScheduler()).tick();
|
||||||
+ getAllLevels().forEach(level -> level.getAllEntities().forEach(entity -> {
|
+ getAllLevels().forEach(level -> {
|
||||||
+ if (entity.isRemoved()) {
|
+ for (final Entity entity : level.getEntityLookup().getAllCopy()) {
|
||||||
+ return;
|
+ if (entity.isRemoved()) {
|
||||||
|
+ continue;
|
||||||
|
+ }
|
||||||
|
+ final org.bukkit.craftbukkit.entity.CraftEntity bukkit = entity.getBukkitEntityRaw();
|
||||||
|
+ if (bukkit != null) {
|
||||||
|
+ bukkit.taskScheduler.executeTick();
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ org.bukkit.craftbukkit.entity.CraftEntity bukkit = entity.getBukkitEntityRaw();
|
+ });
|
||||||
+ if (bukkit != null) {
|
|
||||||
+ bukkit.taskScheduler.executeTick();
|
|
||||||
+ }
|
|
||||||
+ }));
|
|
||||||
+ // Paper end - Folia scheduler API
|
+ // Paper end - Folia scheduler API
|
||||||
io.papermc.paper.adventure.providers.ClickCallbackProviderImpl.CALLBACK_MANAGER.handleQueue(this.tickCount); // Paper
|
io.papermc.paper.adventure.providers.ClickCallbackProviderImpl.CALLBACK_MANAGER.handleQueue(this.tickCount); // Paper
|
||||||
this.profiler.push("commandFunctions");
|
this.profiler.push("commandFunctions");
|
||||||
|
@ -3776,6 +3776,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+import org.jetbrains.annotations.Nullable;
|
+import org.jetbrains.annotations.Nullable;
|
||||||
+import org.slf4j.Logger;
|
+import org.slf4j.Logger;
|
||||||
+import java.util.ArrayList;
|
+import java.util.ArrayList;
|
||||||
|
+import java.util.Arrays;
|
||||||
+import java.util.Iterator;
|
+import java.util.Iterator;
|
||||||
+import java.util.List;
|
+import java.util.List;
|
||||||
+import java.util.NoSuchElementException;
|
+import java.util.NoSuchElementException;
|
||||||
@ -3939,6 +3940,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ return new ArrayIterable<>(this.accessibleEntities.getRawData(), 0, this.accessibleEntities.size());
|
+ return new ArrayIterable<>(this.accessibleEntities.getRawData(), 0, this.accessibleEntities.size());
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
+ public Entity[] getAllCopy() {
|
||||||
|
+ return Arrays.copyOf(this.accessibleEntities.getRawData(), this.accessibleEntities.size(), Entity[].class);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public <U extends Entity> void get(final EntityTypeTest<Entity, U> filter, final AbortableIterationConsumer<U> action) {
|
+ public <U extends Entity> void get(final EntityTypeTest<Entity, U> filter, final AbortableIterationConsumer<U> action) {
|
||||||
+ for (final Entity entity : this.entityById.values()) {
|
+ for (final Entity entity : this.entityById.values()) {
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren