mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-02 22:47:49 +01:00
Fix chunks being registered multiple times (weirdly only happen on Windows?)
Signed-off-by: TheMode <themode@outlook.fr>
This commit is contained in:
parent
8fae759a71
commit
a8d90955c7
@ -49,6 +49,7 @@ public class InstanceContainer extends Instance {
|
|||||||
// (chunk index -> chunk) map, contains all the chunks in the instance
|
// (chunk index -> chunk) map, contains all the chunks in the instance
|
||||||
// used as a monitor when access is required
|
// used as a monitor when access is required
|
||||||
private final Long2ObjectMap<Chunk> chunks = new Long2ObjectOpenHashMap<>();
|
private final Long2ObjectMap<Chunk> chunks = new Long2ObjectOpenHashMap<>();
|
||||||
|
private final Long2ObjectMap<CompletableFuture<Chunk>> loadingChunks = new Long2ObjectOpenHashMap<>();
|
||||||
|
|
||||||
private final Lock changingBlockLock = new ReentrantLock();
|
private final Lock changingBlockLock = new ReentrantLock();
|
||||||
private final Map<Point, Block> currentlyChangingBlocks = new HashMap<>();
|
private final Map<Point, Block> currentlyChangingBlocks = new HashMap<>();
|
||||||
@ -259,6 +260,12 @@ public class InstanceContainer extends Instance {
|
|||||||
|
|
||||||
protected @NotNull CompletableFuture<@NotNull Chunk> retrieveChunk(int chunkX, int chunkZ) {
|
protected @NotNull CompletableFuture<@NotNull Chunk> retrieveChunk(int chunkX, int chunkZ) {
|
||||||
CompletableFuture<Chunk> completableFuture = new CompletableFuture<>();
|
CompletableFuture<Chunk> completableFuture = new CompletableFuture<>();
|
||||||
|
synchronized (loadingChunks) {
|
||||||
|
final long index = ChunkUtils.getChunkIndex(chunkX, chunkZ);
|
||||||
|
CompletableFuture<Chunk> loadingChunk = loadingChunks.get(index);
|
||||||
|
if (loadingChunk != null) return loadingChunk;
|
||||||
|
this.loadingChunks.put(index, completableFuture);
|
||||||
|
}
|
||||||
final IChunkLoader loader = chunkLoader;
|
final IChunkLoader loader = chunkLoader;
|
||||||
final Runnable retriever = () -> loader.loadChunk(this, chunkX, chunkZ)
|
final Runnable retriever = () -> loader.loadChunk(this, chunkX, chunkZ)
|
||||||
// create the chunk from scratch (with the generator) if the loader couldn't
|
// create the chunk from scratch (with the generator) if the loader couldn't
|
||||||
@ -267,6 +274,9 @@ public class InstanceContainer extends Instance {
|
|||||||
.whenComplete((chunk, throwable) -> scheduleNextTick(instance -> {
|
.whenComplete((chunk, throwable) -> scheduleNextTick(instance -> {
|
||||||
cacheChunk(chunk);
|
cacheChunk(chunk);
|
||||||
EventDispatcher.call(new InstanceChunkLoadEvent(this, chunkX, chunkZ));
|
EventDispatcher.call(new InstanceChunkLoadEvent(this, chunkX, chunkZ));
|
||||||
|
synchronized (loadingChunks) {
|
||||||
|
this.loadingChunks.remove(ChunkUtils.getChunkIndex(chunk));
|
||||||
|
}
|
||||||
completableFuture.complete(chunk);
|
completableFuture.complete(chunk);
|
||||||
}));
|
}));
|
||||||
if (loader.supportsParallelLoading()) {
|
if (loader.supportsParallelLoading()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user