Skip to content

Commit

Permalink
Fixed island level zeroing for non-void worlds
Browse files Browse the repository at this point in the history
  • Loading branch information
tastybento committed Jan 20, 2025
1 parent 3a96bb5 commit 9d7b84c
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -309,7 +309,8 @@ private void loadChunks(CompletableFuture<List<Chunk>> r2, World world, Queue<Pa
return;
}
Pair<Integer, Integer> p = pairList.poll();
Util.getChunkAtAsync(world, p.x, p.z, world.getEnvironment().equals(Environment.NETHER)).thenAccept(chunk -> {
// We need to generate now all the time because some game modes are not voids
Util.getChunkAtAsync(world, p.x, p.z, true).thenAccept(chunk -> {
if (chunk != null) {
chunkList.add(chunk);
roseStackerCheck(chunk);
Expand Down Expand Up @@ -613,6 +614,7 @@ public void scanIsland(Pipeliner pipeliner) {
} else {
// Done
pipeliner.getInProcessQueue().remove(this);
BentoBox.getInstance().log("Completed Level scan.");
// Chunk finished
// This was the last chunk. Handle stacked blocks, then chests and exit
handleStackedBlocks().thenCompose(v -> handleChests()).thenRun(() -> {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,10 @@ public Pipeliner(Level addon) {
if (!inProcessQueue.isEmpty() || toProcessQueue.isEmpty()) return;
for (int j = 0; j < addon.getSettings().getConcurrentIslandCalcs() && !toProcessQueue.isEmpty(); j++) {
IslandLevelCalculator iD = toProcessQueue.poll();
// Ignore deleted or unonwed islands
// Ignore deleted or unowned islands
if (!iD.getIsland().isDeleted() && !iD.getIsland().isUnowned()) {
inProcessQueue.put(iD, System.currentTimeMillis());
BentoBox.getInstance().log("Starting to scan island level at " + iD.getIsland().getCenter());
// Start the scanning of a island with the first chunk
scanIsland(iD);
}
Expand Down Expand Up @@ -95,6 +96,7 @@ public CompletableFuture<Results> addIsland(Island island) {
.map(IslandLevelCalculator::getIsland).anyMatch(island::equals)) {
return CompletableFuture.completedFuture(new Results(Result.IN_PROGRESS));
}
BentoBox.getInstance().log("Added island to Level queue: " + island.getCenter());
return addToQueue(island, false);
}

Expand All @@ -104,6 +106,7 @@ public CompletableFuture<Results> addIsland(Island island) {
* @return CompletableFuture of the results
*/
public CompletableFuture<Results> zeroIsland(Island island) {
BentoBox.getInstance().log("Zeroing island level for island at " + island.getCenter());
return addToQueue(island, true);
}

Expand Down

0 comments on commit 9d7b84c

Please sign in to comment.