mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-24 17:22:55 +01:00
SPIGOT-3747: Add API for force loaded chunks
By: md_5 <git@md-5.net>
This commit is contained in:
parent
92e8783d1e
commit
cf4055b264
2 changed files with 32 additions and 0 deletions
|
@ -147,6 +147,16 @@ public class CraftChunk implements Chunk {
|
||||||
return getWorld().unloadChunk(getX(), getZ(), save, safe);
|
return getWorld().unloadChunk(getX(), getZ(), save, safe);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isForceLoaded() {
|
||||||
|
return getWorld().isChunkForceLoaded(getX(), getZ());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setForceLoaded(boolean forced) {
|
||||||
|
getWorld().setChunkForceLoaded(getX(), getZ(), forced);
|
||||||
|
}
|
||||||
|
|
||||||
public ChunkSnapshot getChunkSnapshot() {
|
public ChunkSnapshot getChunkSnapshot() {
|
||||||
return getChunkSnapshot(true, false, false);
|
return getChunkSnapshot(true, false, false);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package org.bukkit.craftbukkit;
|
||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
import com.google.common.util.concurrent.Futures;
|
import com.google.common.util.concurrent.Futures;
|
||||||
|
import it.unimi.dsi.fastutil.longs.LongSet;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
@ -278,6 +279,27 @@ public class CraftWorld implements World {
|
||||||
((CraftChunk) getChunkAt(chunk.getX(), chunk.getZ())).getHandle().bukkitChunk = chunk;
|
((CraftChunk) getChunkAt(chunk.getX(), chunk.getZ())).getHandle().bukkitChunk = chunk;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isChunkForceLoaded(int x, int z) {
|
||||||
|
return getHandle().isForceLoaded(x, z);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setChunkForceLoaded(int x, int z, boolean forced) {
|
||||||
|
getHandle().setForceLoaded(x, z, forced);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Collection<Chunk> getForceLoadedChunks() {
|
||||||
|
Set<Chunk> chunks = new HashSet<>();
|
||||||
|
|
||||||
|
for (long coord : getHandle().ag()) { // PAIL
|
||||||
|
chunks.add(getChunkAt(ChunkCoordIntPair.a(coord), ChunkCoordIntPair.b(coord)));
|
||||||
|
}
|
||||||
|
|
||||||
|
return Collections.unmodifiableCollection(chunks);
|
||||||
|
}
|
||||||
|
|
||||||
public WorldServer getHandle() {
|
public WorldServer getHandle() {
|
||||||
return world;
|
return world;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue