mirror of
https://github.com/PaperMC/Folia.git
synced 2024-11-24 12:25:23 +01:00
Initial commit
This commit is contained in:
parent
08b84c277d
commit
62c1166ee5
4
.gitignore
vendored
4
.gitignore
vendored
@ -46,7 +46,7 @@ out/
|
|||||||
# other stuff
|
# other stuff
|
||||||
run/
|
run/
|
||||||
|
|
||||||
forktest-server
|
folia-server
|
||||||
forktest-api
|
folia-api
|
||||||
|
|
||||||
!gradle/wrapper/gradle-wrapper.jar
|
!gradle/wrapper/gradle-wrapper.jar
|
||||||
|
@ -50,7 +50,7 @@ subprojects {
|
|||||||
}
|
}
|
||||||
|
|
||||||
paperweight {
|
paperweight {
|
||||||
serverProject.set(project(":forktest-server"))
|
serverProject.set(project(":Folia-Server"))
|
||||||
|
|
||||||
remapRepo.set(paperMavenPublicUrl)
|
remapRepo.set(paperMavenPublicUrl)
|
||||||
decompileRepo.set(paperMavenPublicUrl)
|
decompileRepo.set(paperMavenPublicUrl)
|
||||||
@ -58,10 +58,10 @@ paperweight {
|
|||||||
usePaperUpstream(providers.gradleProperty("paperRef")) {
|
usePaperUpstream(providers.gradleProperty("paperRef")) {
|
||||||
withPaperPatcher {
|
withPaperPatcher {
|
||||||
apiPatchDir.set(layout.projectDirectory.dir("patches/api"))
|
apiPatchDir.set(layout.projectDirectory.dir("patches/api"))
|
||||||
apiOutputDir.set(layout.projectDirectory.dir("forktest-api"))
|
apiOutputDir.set(layout.projectDirectory.dir("Folia-API"))
|
||||||
|
|
||||||
serverPatchDir.set(layout.projectDirectory.dir("patches/server"))
|
serverPatchDir.set(layout.projectDirectory.dir("patches/server"))
|
||||||
serverOutputDir.set(layout.projectDirectory.dir("forktest-server"))
|
serverOutputDir.set(layout.projectDirectory.dir("Folia-Server"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -71,20 +71,20 @@ paperweight {
|
|||||||
//
|
//
|
||||||
|
|
||||||
tasks.generateDevelopmentBundle {
|
tasks.generateDevelopmentBundle {
|
||||||
apiCoordinates.set("com.example.paperfork:forktest-api")
|
apiCoordinates.set("dev.folia:folia-api")
|
||||||
mojangApiCoordinates.set("io.papermc.paper:paper-mojangapi")
|
mojangApiCoordinates.set("io.papermc.paper:paper-mojangapi")
|
||||||
libraryRepositories.set(
|
libraryRepositories.set(
|
||||||
listOf(
|
listOf(
|
||||||
"https://repo.maven.apache.org/maven2/",
|
"https://repo.maven.apache.org/maven2/",
|
||||||
paperMavenPublicUrl,
|
paperMavenPublicUrl,
|
||||||
// "https://my.repo/", // This should be a repo hosting your API (in this example, 'com.example.paperfork:forktest-api')
|
// "https://my.repo/", // This should be a repo hosting your API (in this example, 'dev.folia:folia-api')
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
allprojects {
|
allprojects {
|
||||||
// Publishing API:
|
// Publishing API:
|
||||||
// ./gradlew :ForkTest-API:publish[ToMavenLocal]
|
// ./gradlew :folia-API:publish[ToMavenLocal]
|
||||||
publishing {
|
publishing {
|
||||||
repositories {
|
repositories {
|
||||||
maven {
|
maven {
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
group=com.example.paperfork
|
group=dev.folia
|
||||||
version=1.19.3-R0.1-SNAPSHOT
|
version=1.19.3-R0.1-SNAPSHOT
|
||||||
|
|
||||||
mcVersion=1.19.3
|
mcVersion=1.19.3
|
||||||
paperRef=adb8e499dbc6050abf4a690d369cf506bc3ac318
|
paperRef=4da844f1e3e375a24a0e518b0787ae909fa0e247
|
||||||
|
|
||||||
org.gradle.caching=true
|
org.gradle.caching=true
|
||||||
org.gradle.parallel=true
|
org.gradle.parallel=true
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: MiniDigger <admin@minidigger.me>
|
From: Spottedleaf <Spottedleaf@users.noreply.github.com>
|
||||||
Date: Sat, 12 Jun 2021 16:40:34 +0200
|
Date: Thu, 23 Feb 2023 07:56:29 -0800
|
||||||
Subject: [PATCH] Build changes
|
Subject: [PATCH] Build changes
|
||||||
|
|
||||||
|
|
||||||
diff --git a/build.gradle.kts b/build.gradle.kts
|
diff --git a/build.gradle.kts b/build.gradle.kts
|
||||||
index d5d49bb2b47c889e12d17dc87b8c439a60b3fe67..497db79710a93e18c245ba8ac5853dd5ac6012b5 100644
|
index 781609605d25283009e5f3e61649ecde9ea9a4cb..0a389871b8bd66252455773a6d735576a1bfcd77 100644
|
||||||
--- a/build.gradle.kts
|
--- a/build.gradle.kts
|
||||||
+++ b/build.gradle.kts
|
+++ b/build.gradle.kts
|
||||||
@@ -7,8 +7,12 @@ plugins {
|
@@ -7,8 +7,12 @@ plugins {
|
||||||
@ -14,12 +14,12 @@ index d5d49bb2b47c889e12d17dc87b8c439a60b3fe67..497db79710a93e18c245ba8ac5853dd5
|
|||||||
dependencies {
|
dependencies {
|
||||||
- implementation(project(":paper-api"))
|
- implementation(project(":paper-api"))
|
||||||
- implementation(project(":paper-mojangapi"))
|
- implementation(project(":paper-mojangapi"))
|
||||||
+ // ForkTest start
|
+ // Folia start
|
||||||
+ implementation(project(":forktest-api"))
|
+ implementation(project(":Folia-API"))
|
||||||
+ implementation("io.papermc.paper:paper-mojangapi:1.19.3-R0.1-SNAPSHOT") {
|
+ implementation("io.papermc.paper:paper-mojangapi:1.19.3-R0.1-SNAPSHOT") {
|
||||||
+ exclude("io.papermc.paper", "paper-api")
|
+ exclude("io.papermc.paper", "paper-api")
|
||||||
+ }
|
+ }
|
||||||
+ // ForkTest end
|
+ // Folia end
|
||||||
// Paper start
|
// Paper start
|
||||||
implementation("org.jline:jline-terminal-jansi:3.21.0")
|
implementation("org.jline:jline-terminal-jansi:3.21.0")
|
||||||
implementation("net.minecrell:terminalconsoleappender:1.3.0")
|
implementation("net.minecrell:terminalconsoleappender:1.3.0")
|
||||||
@ -28,7 +28,7 @@ index d5d49bb2b47c889e12d17dc87b8c439a60b3fe67..497db79710a93e18c245ba8ac5853dd5
|
|||||||
"Main-Class" to "org.bukkit.craftbukkit.Main",
|
"Main-Class" to "org.bukkit.craftbukkit.Main",
|
||||||
"Implementation-Title" to "CraftBukkit",
|
"Implementation-Title" to "CraftBukkit",
|
||||||
- "Implementation-Version" to "git-Paper-$implementationVersion",
|
- "Implementation-Version" to "git-Paper-$implementationVersion",
|
||||||
+ "Implementation-Version" to "git-ForkTest-$implementationVersion", // ForkTest
|
+ "Implementation-Version" to "git-Folia-$implementationVersion", // Folia
|
||||||
"Implementation-Vendor" to date, // Paper
|
"Implementation-Vendor" to date, // Paper
|
||||||
"Specification-Title" to "Bukkit",
|
"Specification-Title" to "Bukkit",
|
||||||
"Specification-Version" to project.version,
|
"Specification-Version" to project.version,
|
||||||
@ -37,12 +37,12 @@ index d5d49bb2b47c889e12d17dc87b8c439a60b3fe67..497db79710a93e18c245ba8ac5853dd5
|
|||||||
block: JavaExec.() -> Unit
|
block: JavaExec.() -> Unit
|
||||||
): TaskProvider<JavaExec> = register<JavaExec>(name) {
|
): TaskProvider<JavaExec> = register<JavaExec>(name) {
|
||||||
- group = "paper"
|
- group = "paper"
|
||||||
+ group = "paperweight" // ForkTest
|
+ group = "paperweight" // Folia
|
||||||
mainClass.set("org.bukkit.craftbukkit.Main")
|
mainClass.set("org.bukkit.craftbukkit.Main")
|
||||||
standardInput = System.`in`
|
standardInput = System.`in`
|
||||||
workingDir = rootProject.layout.projectDirectory
|
workingDir = rootProject.layout.projectDirectory
|
||||||
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
||||||
index 710ca7d3a5659953f64bc6dccdd93b43300961cc..57e0aa0341b359442e562ef4e213b1c785841788 100644
|
index 710ca7d3a5659953f64bc6dccdd93b43300961cc..2ee4e5e8d17a3a1e6a342c74b13135df030ffef6 100644
|
||||||
--- a/src/main/java/net/minecraft/server/MinecraftServer.java
|
--- a/src/main/java/net/minecraft/server/MinecraftServer.java
|
||||||
+++ b/src/main/java/net/minecraft/server/MinecraftServer.java
|
+++ b/src/main/java/net/minecraft/server/MinecraftServer.java
|
||||||
@@ -1654,7 +1654,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
@@ -1654,7 +1654,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
||||||
@ -50,12 +50,12 @@ index 710ca7d3a5659953f64bc6dccdd93b43300961cc..57e0aa0341b359442e562ef4e213b1c7
|
|||||||
@DontObfuscate
|
@DontObfuscate
|
||||||
public String getServerModName() {
|
public String getServerModName() {
|
||||||
- return "Paper"; // Paper - Paper > // Spigot - Spigot > // CraftBukkit - cb > vanilla!
|
- return "Paper"; // Paper - Paper > // Spigot - Spigot > // CraftBukkit - cb > vanilla!
|
||||||
+ return "ForkTest"; // ForkTest - ForkTest > // Paper - Paper > // Spigot - Spigot > // CraftBukkit - cb > vanilla!
|
+ return "Folia"; // Folia - Folia > // Paper - Paper > // Spigot - Spigot > // CraftBukkit - cb > vanilla!
|
||||||
}
|
}
|
||||||
|
|
||||||
public SystemReport fillSystemReport(SystemReport details) {
|
public SystemReport fillSystemReport(SystemReport details) {
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
||||||
index 47df6f4268a63118da8187f4102c876bd37d1680..24a3c5228fe22683bc87c0c6251a9e49b9426ad7 100644
|
index bfc4ee36befb925ab4eb6b96f5c1aa6c76bf711f..2ea3778ee1348e5d06b15a2c5dc5d9bd4136dbe3 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
||||||
@@ -261,7 +261,7 @@ import javax.annotation.Nullable; // Paper
|
@@ -261,7 +261,7 @@ import javax.annotation.Nullable; // Paper
|
||||||
@ -63,12 +63,12 @@ index 47df6f4268a63118da8187f4102c876bd37d1680..24a3c5228fe22683bc87c0c6251a9e49
|
|||||||
|
|
||||||
public final class CraftServer implements Server {
|
public final class CraftServer implements Server {
|
||||||
- private final String serverName = "Paper"; // Paper
|
- private final String serverName = "Paper"; // Paper
|
||||||
+ private final String serverName = "ForkTest"; // ForkTest // Paper
|
+ private final String serverName = "Folia"; // Folia // Paper
|
||||||
private final String serverVersion;
|
private final String serverVersion;
|
||||||
private final String bukkitVersion = Versioning.getBukkitVersion();
|
private final String bukkitVersion = Versioning.getBukkitVersion();
|
||||||
private final Logger logger = Logger.getLogger("Minecraft");
|
private final Logger logger = Logger.getLogger("Minecraft");
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/util/Versioning.java b/src/main/java/org/bukkit/craftbukkit/util/Versioning.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/util/Versioning.java b/src/main/java/org/bukkit/craftbukkit/util/Versioning.java
|
||||||
index 774556a62eb240da42e84db4502e2ed43495be17..21f39bd0c33ef2635249298e6a247afba8b05742 100644
|
index 774556a62eb240da42e84db4502e2ed43495be17..e9b6ca3aa25e140467ae866d572483050ea3fa0e 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/util/Versioning.java
|
--- a/src/main/java/org/bukkit/craftbukkit/util/Versioning.java
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/util/Versioning.java
|
+++ b/src/main/java/org/bukkit/craftbukkit/util/Versioning.java
|
||||||
@@ -11,7 +11,7 @@ public final class Versioning {
|
@@ -11,7 +11,7 @@ public final class Versioning {
|
||||||
@ -76,7 +76,7 @@ index 774556a62eb240da42e84db4502e2ed43495be17..21f39bd0c33ef2635249298e6a247afb
|
|||||||
String result = "Unknown-Version";
|
String result = "Unknown-Version";
|
||||||
|
|
||||||
- InputStream stream = Bukkit.class.getClassLoader().getResourceAsStream("META-INF/maven/io.papermc.paper/paper-api/pom.properties");
|
- InputStream stream = Bukkit.class.getClassLoader().getResourceAsStream("META-INF/maven/io.papermc.paper/paper-api/pom.properties");
|
||||||
+ InputStream stream = Bukkit.class.getClassLoader().getResourceAsStream("META-INF/maven/com.example.paperfork/forktest-api/pom.properties"); // ForkTest
|
+ InputStream stream = Bukkit.class.getClassLoader().getResourceAsStream("META-INF/maven/dev.folia/folia-api/pom.properties"); // Folia
|
||||||
Properties properties = new Properties();
|
Properties properties = new Properties();
|
||||||
|
|
||||||
if (stream != null) {
|
if (stream != null) {
|
||||||
|
2281
patches/server/0002-New-player-chunk-loader-system.patch
Normal file
2281
patches/server/0002-New-player-chunk-loader-system.patch
Normal file
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,395 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Spottedleaf <Spottedleaf@users.noreply.github.com>
|
||||||
|
Date: Thu, 16 Feb 2023 16:50:05 -0800
|
||||||
|
Subject: [PATCH] Make ChunkStatus.EMPTY not rely on the main thread for
|
||||||
|
completion
|
||||||
|
|
||||||
|
In order to do this, we need to push the POI consistency checks
|
||||||
|
to a later status. Since FULL is the only other status that
|
||||||
|
uses the main thread, it can go there.
|
||||||
|
|
||||||
|
The consistency checks are only really for when a desync occurs,
|
||||||
|
and so that delaying the check only matters when the chunk data
|
||||||
|
has desync'd. As long as the desync is sorted before the
|
||||||
|
chunk is full loaded (i.e before setBlock can occur on
|
||||||
|
a chunk), it should not matter.
|
||||||
|
|
||||||
|
This change is primarily due to behavioural changes
|
||||||
|
in the chunk task queue brought by region threading -
|
||||||
|
which is to split the queue into separate regions. As such,
|
||||||
|
it is required that in order for the sync load to complete
|
||||||
|
that the region owning the chunk drain and execute the task
|
||||||
|
while ticking. However, that is not always possible in
|
||||||
|
region threading. Thus, removing the main thread reliance allows
|
||||||
|
the chunk to progress without requiring a tick thread.
|
||||||
|
Specifically, this allows far sync loads (outside of a specific
|
||||||
|
regions bounds) to occur without issue - namely with structure
|
||||||
|
searching.
|
||||||
|
|
||||||
|
diff --git a/src/main/java/io/papermc/paper/chunk/system/scheduling/ChunkFullTask.java b/src/main/java/io/papermc/paper/chunk/system/scheduling/ChunkFullTask.java
|
||||||
|
index fb42d776f15f735fb59e972e00e2b512c23a8387..300700477ee34bc22b31315825c0e40f61070cd5 100644
|
||||||
|
--- a/src/main/java/io/papermc/paper/chunk/system/scheduling/ChunkFullTask.java
|
||||||
|
+++ b/src/main/java/io/papermc/paper/chunk/system/scheduling/ChunkFullTask.java
|
||||||
|
@@ -2,6 +2,8 @@ package io.papermc.paper.chunk.system.scheduling;
|
||||||
|
|
||||||
|
import ca.spottedleaf.concurrentutil.executor.standard.PrioritisedExecutor;
|
||||||
|
import ca.spottedleaf.concurrentutil.util.ConcurrentUtil;
|
||||||
|
+import com.mojang.logging.LogUtils;
|
||||||
|
+import io.papermc.paper.chunk.system.poi.PoiChunk;
|
||||||
|
import net.minecraft.server.level.ChunkMap;
|
||||||
|
import net.minecraft.server.level.ServerLevel;
|
||||||
|
import net.minecraft.world.level.chunk.ChunkAccess;
|
||||||
|
@@ -9,10 +11,13 @@ import net.minecraft.world.level.chunk.ChunkStatus;
|
||||||
|
import net.minecraft.world.level.chunk.ImposterProtoChunk;
|
||||||
|
import net.minecraft.world.level.chunk.LevelChunk;
|
||||||
|
import net.minecraft.world.level.chunk.ProtoChunk;
|
||||||
|
+import org.slf4j.Logger;
|
||||||
|
import java.lang.invoke.VarHandle;
|
||||||
|
|
||||||
|
public final class ChunkFullTask extends ChunkProgressionTask implements Runnable {
|
||||||
|
|
||||||
|
+ private static final Logger LOGGER = LogUtils.getClassLogger();
|
||||||
|
+
|
||||||
|
protected final NewChunkHolder chunkHolder;
|
||||||
|
protected final ChunkAccess fromChunk;
|
||||||
|
protected final PrioritisedExecutor.PrioritisedTask convertToFullTask;
|
||||||
|
@@ -35,6 +40,15 @@ public final class ChunkFullTask extends ChunkProgressionTask implements Runnabl
|
||||||
|
// See Vanilla protoChunkToFullChunk for what this function should be doing
|
||||||
|
final LevelChunk chunk;
|
||||||
|
try {
|
||||||
|
+ // moved from the load from nbt stage into here
|
||||||
|
+ final PoiChunk poiChunk = this.chunkHolder.getPoiChunk();
|
||||||
|
+ if (poiChunk == null) {
|
||||||
|
+ LOGGER.error("Expected poi chunk to be loaded with chunk for task " + this.toString());
|
||||||
|
+ } else {
|
||||||
|
+ poiChunk.load();
|
||||||
|
+ this.world.getPoiManager().checkConsistency(this.fromChunk);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if (this.fromChunk instanceof ImposterProtoChunk wrappedFull) {
|
||||||
|
chunk = wrappedFull.getWrapped();
|
||||||
|
} else {
|
||||||
|
diff --git a/src/main/java/io/papermc/paper/chunk/system/scheduling/ChunkLoadTask.java b/src/main/java/io/papermc/paper/chunk/system/scheduling/ChunkLoadTask.java
|
||||||
|
index 3df793f7e6bb67f40e7387a72fdafb912a7b1373..31657c387156f789d5c04ad3413d049bc32f1359 100644
|
||||||
|
--- a/src/main/java/io/papermc/paper/chunk/system/scheduling/ChunkLoadTask.java
|
||||||
|
+++ b/src/main/java/io/papermc/paper/chunk/system/scheduling/ChunkLoadTask.java
|
||||||
|
@@ -25,6 +25,7 @@ import org.slf4j.Logger;
|
||||||
|
import java.lang.invoke.VarHandle;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
+import java.util.concurrent.atomic.AtomicLong;
|
||||||
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
|
public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
@@ -34,9 +35,11 @@ public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
private final NewChunkHolder chunkHolder;
|
||||||
|
private final ChunkDataLoadTask loadTask;
|
||||||
|
|
||||||
|
- private boolean cancelled;
|
||||||
|
+ private volatile boolean cancelled;
|
||||||
|
private NewChunkHolder.GenericDataLoadTaskCallback entityLoadTask;
|
||||||
|
private NewChunkHolder.GenericDataLoadTaskCallback poiLoadTask;
|
||||||
|
+ private GenericDataLoadTask.TaskResult<ChunkAccess, Throwable> loadResult;
|
||||||
|
+ private final AtomicInteger taskCountToComplete = new AtomicInteger(3); // one for poi, one for entity, and one for chunk data
|
||||||
|
|
||||||
|
protected ChunkLoadTask(final ChunkTaskScheduler scheduler, final ServerLevel world, final int chunkX, final int chunkZ,
|
||||||
|
final NewChunkHolder chunkHolder, final PrioritisedExecutor.Priority priority) {
|
||||||
|
@@ -44,10 +47,18 @@ public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
this.chunkHolder = chunkHolder;
|
||||||
|
this.loadTask = new ChunkDataLoadTask(scheduler, world, chunkX, chunkZ, priority);
|
||||||
|
this.loadTask.addCallback((final GenericDataLoadTask.TaskResult<ChunkAccess, Throwable> result) -> {
|
||||||
|
- ChunkLoadTask.this.complete(result == null ? null : result.left(), result == null ? null : result.right());
|
||||||
|
+ ChunkLoadTask.this.loadResult = result; // must be before getAndDecrement
|
||||||
|
+ ChunkLoadTask.this.tryCompleteLoad();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
+ private void tryCompleteLoad() {
|
||||||
|
+ if (this.taskCountToComplete.decrementAndGet() == 0) {
|
||||||
|
+ final GenericDataLoadTask.TaskResult<ChunkAccess, Throwable> result = this.cancelled ? null : this.loadResult; // only after the getAndDecrement
|
||||||
|
+ ChunkLoadTask.this.complete(result == null ? null : result.left(), result == null ? null : result.right());
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
@Override
|
||||||
|
public ChunkStatus getTargetStatus() {
|
||||||
|
return ChunkStatus.EMPTY;
|
||||||
|
@@ -65,11 +76,8 @@ public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
final NewChunkHolder.GenericDataLoadTaskCallback entityLoadTask;
|
||||||
|
final NewChunkHolder.GenericDataLoadTaskCallback poiLoadTask;
|
||||||
|
|
||||||
|
- final AtomicInteger count = new AtomicInteger();
|
||||||
|
final Consumer<GenericDataLoadTask.TaskResult<?, ?>> scheduleLoadTask = (final GenericDataLoadTask.TaskResult<?, ?> result) -> {
|
||||||
|
- if (count.decrementAndGet() == 0) {
|
||||||
|
- ChunkLoadTask.this.loadTask.schedule(false);
|
||||||
|
- }
|
||||||
|
+ ChunkLoadTask.this.tryCompleteLoad();
|
||||||
|
};
|
||||||
|
|
||||||
|
// NOTE: it is IMPOSSIBLE for getOrLoadEntityData/getOrLoadPoiData to complete synchronously, because
|
||||||
|
@@ -85,16 +93,16 @@ public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
}
|
||||||
|
if (!this.chunkHolder.isEntityChunkNBTLoaded()) {
|
||||||
|
entityLoadTask = this.chunkHolder.getOrLoadEntityData((Consumer)scheduleLoadTask);
|
||||||
|
- count.setPlain(count.getPlain() + 1);
|
||||||
|
} else {
|
||||||
|
entityLoadTask = null;
|
||||||
|
+ this.taskCountToComplete.getAndDecrement(); // we know the chunk load is not done here, as it is not scheduled
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!this.chunkHolder.isPoiChunkLoaded()) {
|
||||||
|
poiLoadTask = this.chunkHolder.getOrLoadPoiData((Consumer)scheduleLoadTask);
|
||||||
|
- count.setPlain(count.getPlain() + 1);
|
||||||
|
} else {
|
||||||
|
poiLoadTask = null;
|
||||||
|
+ this.taskCountToComplete.getAndDecrement(); // we know the chunk load is not done here, as it is not scheduled
|
||||||
|
}
|
||||||
|
|
||||||
|
this.entityLoadTask = entityLoadTask;
|
||||||
|
@@ -107,14 +115,11 @@ public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
entityLoadTask.schedule();
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (poiLoadTask != null) {
|
||||||
|
+ if (poiLoadTask != null) {
|
||||||
|
poiLoadTask.schedule();
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (entityLoadTask == null && poiLoadTask == null) {
|
||||||
|
- // no need to wait on those, we can schedule now
|
||||||
|
- this.loadTask.schedule(false);
|
||||||
|
- }
|
||||||
|
+ this.loadTask.schedule(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@@ -129,15 +134,20 @@ public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
|
||||||
|
/*
|
||||||
|
Note: The entityLoadTask/poiLoadTask do not complete when cancelled,
|
||||||
|
- but this is fine because if they are successfully cancelled then
|
||||||
|
- we will successfully cancel the load task, which will complete when cancelled
|
||||||
|
+ so we need to manually try to complete in those cases
|
||||||
|
+ It is also important to note that we set the cancelled field first, just in case
|
||||||
|
+ the chunk load task attempts to complete with a non-null value
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (this.entityLoadTask != null) {
|
||||||
|
- this.entityLoadTask.cancel();
|
||||||
|
+ if (this.entityLoadTask.cancel()) {
|
||||||
|
+ this.tryCompleteLoad();
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
if (this.poiLoadTask != null) {
|
||||||
|
- this.poiLoadTask.cancel();
|
||||||
|
+ if (this.poiLoadTask.cancel()) {
|
||||||
|
+ this.tryCompleteLoad();
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
this.loadTask.cancel();
|
||||||
|
}
|
||||||
|
@@ -249,7 +259,7 @@ public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- public final class ChunkDataLoadTask extends CallbackDataLoadTask<ChunkSerializer.InProgressChunkHolder, ChunkAccess> {
|
||||||
|
+ public static final class ChunkDataLoadTask extends CallbackDataLoadTask<ChunkAccess, ChunkAccess> {
|
||||||
|
protected ChunkDataLoadTask(final ChunkTaskScheduler scheduler, final ServerLevel world, final int chunkX,
|
||||||
|
final int chunkZ, final PrioritisedExecutor.Priority priority) {
|
||||||
|
super(scheduler, world, chunkX, chunkZ, RegionFileIOThread.RegionFileType.CHUNK_DATA, priority);
|
||||||
|
@@ -262,7 +272,7 @@ public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean hasOnMain() {
|
||||||
|
- return true;
|
||||||
|
+ return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@@ -272,35 +282,30 @@ public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected PrioritisedExecutor.PrioritisedTask createOnMain(final Runnable run, final PrioritisedExecutor.Priority priority) {
|
||||||
|
- return this.scheduler.createChunkTask(this.chunkX, this.chunkZ, run, priority);
|
||||||
|
+ throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
- protected TaskResult<ChunkAccess, Throwable> completeOnMainOffMain(final ChunkSerializer.InProgressChunkHolder data, final Throwable throwable) {
|
||||||
|
- if (data != null) {
|
||||||
|
- return null;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- final PoiChunk poiChunk = ChunkLoadTask.this.chunkHolder.getPoiChunk();
|
||||||
|
- if (poiChunk == null) {
|
||||||
|
- LOGGER.error("Expected poi chunk to be loaded with chunk for task " + this.toString());
|
||||||
|
- } else if (!poiChunk.isLoaded()) {
|
||||||
|
- // need to call poiChunk.load() on main
|
||||||
|
- return null;
|
||||||
|
- }
|
||||||
|
+ protected TaskResult<ChunkAccess, Throwable> completeOnMainOffMain(final ChunkAccess data, final Throwable throwable) {
|
||||||
|
+ throw new UnsupportedOperationException();
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- return new TaskResult<>(this.getEmptyChunk(), null);
|
||||||
|
+ private ProtoChunk getEmptyChunk() {
|
||||||
|
+ return new ProtoChunk(
|
||||||
|
+ new ChunkPos(this.chunkX, this.chunkZ), UpgradeData.EMPTY, this.world,
|
||||||
|
+ this.world.registryAccess().registryOrThrow(Registries.BIOME), (BlendingData)null
|
||||||
|
+ );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
- protected TaskResult<ChunkSerializer.InProgressChunkHolder, Throwable> runOffMain(final CompoundTag data, final Throwable throwable) {
|
||||||
|
+ protected TaskResult<ChunkAccess, Throwable> runOffMain(final CompoundTag data, final Throwable throwable) {
|
||||||
|
if (throwable != null) {
|
||||||
|
LOGGER.error("Failed to load chunk data for task: " + this.toString() + ", chunk data will be lost", throwable);
|
||||||
|
- return new TaskResult<>(null, null);
|
||||||
|
+ return new TaskResult<>(this.getEmptyChunk(), null);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (data == null) {
|
||||||
|
- return new TaskResult<>(null, null);
|
||||||
|
+ return new TaskResult<>(this.getEmptyChunk(), null);
|
||||||
|
}
|
||||||
|
|
||||||
|
// need to convert data, and then deserialize it
|
||||||
|
@@ -319,53 +324,18 @@ public final class ChunkLoadTask extends ChunkProgressionTask {
|
||||||
|
this.world, chunkMap.getPoiManager(), chunkPos, converted, true
|
||||||
|
);
|
||||||
|
|
||||||
|
- return new TaskResult<>(chunkHolder, null);
|
||||||
|
+ return new TaskResult<>(chunkHolder.protoChunk, null);
|
||||||
|
} catch (final ThreadDeath death) {
|
||||||
|
throw death;
|
||||||
|
} catch (final Throwable thr2) {
|
||||||
|
LOGGER.error("Failed to parse chunk data for task: " + this.toString() + ", chunk data will be lost", thr2);
|
||||||
|
- return new TaskResult<>(null, thr2);
|
||||||
|
+ return new TaskResult<>(this.getEmptyChunk(), thr2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- private ProtoChunk getEmptyChunk() {
|
||||||
|
- return new ProtoChunk(
|
||||||
|
- new ChunkPos(this.chunkX, this.chunkZ), UpgradeData.EMPTY, this.world,
|
||||||
|
- this.world.registryAccess().registryOrThrow(Registries.BIOME), (BlendingData)null
|
||||||
|
- );
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
@Override
|
||||||
|
- protected TaskResult<ChunkAccess, Throwable> runOnMain(final ChunkSerializer.InProgressChunkHolder data, final Throwable throwable) {
|
||||||
|
- final PoiChunk poiChunk = ChunkLoadTask.this.chunkHolder.getPoiChunk();
|
||||||
|
- if (poiChunk == null) {
|
||||||
|
- LOGGER.error("Expected poi chunk to be loaded with chunk for task " + this.toString());
|
||||||
|
- } else {
|
||||||
|
- poiChunk.load();
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- if (data == null || data.protoChunk == null) {
|
||||||
|
- // throwable could be non-null, but the off-main task will print its exceptions - so we don't need to care,
|
||||||
|
- // it's handled already
|
||||||
|
-
|
||||||
|
- return new TaskResult<>(this.getEmptyChunk(), null);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- // have tasks to run (at this point, it's just the POI consistency checking)
|
||||||
|
- try {
|
||||||
|
- if (data.tasks != null) {
|
||||||
|
- for (int i = 0, len = data.tasks.size(); i < len; ++i) {
|
||||||
|
- data.tasks.poll().run();
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- return new TaskResult<>(data.protoChunk, null);
|
||||||
|
- } catch (final ThreadDeath death) {
|
||||||
|
- throw death;
|
||||||
|
- } catch (final Throwable thr2) {
|
||||||
|
- LOGGER.error("Failed to parse main tasks for task " + this.toString() + ", chunk data will be lost", thr2);
|
||||||
|
- return new TaskResult<>(this.getEmptyChunk(), null);
|
||||||
|
- }
|
||||||
|
+ protected TaskResult<ChunkAccess, Throwable> runOnMain(final ChunkAccess data, final Throwable throwable) {
|
||||||
|
+ throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/entity/ai/village/poi/PoiManager.java b/src/main/java/net/minecraft/world/entity/ai/village/poi/PoiManager.java
|
||||||
|
index 8950b220b9a3512cd4667beb7bdec0e82e07edc6..9be85eb0abec02bc0e0eded71c34ab1c565c63e7 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/entity/ai/village/poi/PoiManager.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/entity/ai/village/poi/PoiManager.java
|
||||||
|
@@ -328,6 +328,12 @@ public class PoiManager extends SectionStorage<PoiSection> {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ public void checkConsistency(net.minecraft.world.level.chunk.ChunkAccess chunk) {
|
||||||
|
+ for (LevelChunkSection section : chunk.getSections()) {
|
||||||
|
+ this.checkConsistencyWithBlocks(chunk.getPos(), section);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
// Paper end - rewrite chunk system
|
||||||
|
|
||||||
|
public void checkConsistencyWithBlocks(ChunkPos chunkPos, LevelChunkSection chunkSection) {
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java b/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java
|
||||||
|
index d4c4d37bcef14e392739d9aae9e20b7d69b05c12..256642f2e2aa66f7e8c00cae91a75060a8817c9c 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java
|
||||||
|
@@ -122,13 +122,11 @@ public class ChunkSerializer {
|
||||||
|
public static final class InProgressChunkHolder {
|
||||||
|
|
||||||
|
public final ProtoChunk protoChunk;
|
||||||
|
- public final java.util.ArrayDeque<Runnable> tasks;
|
||||||
|
|
||||||
|
public CompoundTag poiData;
|
||||||
|
|
||||||
|
- public InProgressChunkHolder(final ProtoChunk protoChunk, final java.util.ArrayDeque<Runnable> tasks) {
|
||||||
|
+ public InProgressChunkHolder(final ProtoChunk protoChunk) {
|
||||||
|
this.protoChunk = protoChunk;
|
||||||
|
- this.tasks = tasks;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Paper end
|
||||||
|
@@ -136,7 +134,6 @@ public class ChunkSerializer {
|
||||||
|
public static ProtoChunk read(ServerLevel world, PoiManager poiStorage, ChunkPos chunkPos, CompoundTag nbt) {
|
||||||
|
// Paper start - add variant for async calls
|
||||||
|
InProgressChunkHolder holder = loadChunk(world, poiStorage, chunkPos, nbt, true);
|
||||||
|
- holder.tasks.forEach(Runnable::run);
|
||||||
|
return holder.protoChunk;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -145,7 +142,6 @@ public class ChunkSerializer {
|
||||||
|
private static final boolean JUST_CORRUPT_IT = Boolean.getBoolean("Paper.ignoreWorldDataVersion");
|
||||||
|
// Paper end
|
||||||
|
public static InProgressChunkHolder loadChunk(ServerLevel world, PoiManager poiStorage, ChunkPos chunkPos, CompoundTag nbt, boolean distinguish) {
|
||||||
|
- java.util.ArrayDeque<Runnable> tasksToExecuteOnMain = new java.util.ArrayDeque<>();
|
||||||
|
// Paper end
|
||||||
|
// Paper start - Do NOT attempt to load chunks saved with newer versions
|
||||||
|
if (nbt.contains("DataVersion", 99)) {
|
||||||
|
@@ -223,9 +219,7 @@ public class ChunkSerializer {
|
||||||
|
LevelChunkSection chunksection = new LevelChunkSection(b0, datapaletteblock, (PalettedContainer) object); // CraftBukkit - read/write
|
||||||
|
|
||||||
|
achunksection[k] = chunksection;
|
||||||
|
- tasksToExecuteOnMain.add(() -> { // Paper - delay this task since we're executing off-main
|
||||||
|
- poiStorage.checkConsistencyWithBlocks(chunkPos, chunksection);
|
||||||
|
- }); // Paper - delay this task since we're executing off-main
|
||||||
|
+ // Paper - rewrite chunk system - moved to final load stage
|
||||||
|
}
|
||||||
|
|
||||||
|
boolean flag3 = nbttagcompound1.contains("BlockLight", 7);
|
||||||
|
@@ -403,7 +397,7 @@ public class ChunkSerializer {
|
||||||
|
}
|
||||||
|
|
||||||
|
if (chunkstatus_type == ChunkStatus.ChunkType.LEVELCHUNK) {
|
||||||
|
- return new InProgressChunkHolder(new ImposterProtoChunk((LevelChunk) object1, false), tasksToExecuteOnMain); // Paper - Async chunk loading
|
||||||
|
+ return new InProgressChunkHolder(new ImposterProtoChunk((LevelChunk) object1, false)); // Paper - Async chunk loading
|
||||||
|
} else {
|
||||||
|
ProtoChunk protochunk1 = (ProtoChunk) object1;
|
||||||
|
|
||||||
|
@@ -446,7 +440,7 @@ public class ChunkSerializer {
|
||||||
|
protochunk1.setCarvingMask(worldgenstage_features, new CarvingMask(nbttagcompound4.getLongArray(s1), ((ChunkAccess) object1).getMinBuildHeight()));
|
||||||
|
}
|
||||||
|
|
||||||
|
- return new InProgressChunkHolder(protochunk1, tasksToExecuteOnMain); // Paper - Async chunk loading
|
||||||
|
+ return new InProgressChunkHolder(protochunk1); // Paper - Async chunk loading
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
20522
patches/server/0004-Threaded-Regions.patch
Normal file
20522
patches/server/0004-Threaded-Regions.patch
Normal file
File diff suppressed because it is too large
Load Diff
@ -5,6 +5,6 @@ pluginManagement {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
rootProject.name = "forktest"
|
rootProject.name = "Folia"
|
||||||
|
|
||||||
include("forktest-api", "forktest-server")
|
include("Folia-API", "Folia-Server")
|
||||||
|
Loading…
Reference in New Issue
Block a user