--- a/folia-server/build.gradle.kts +++ b/folia-server/build.gradle.kts @@ -29,6 +_,7 @@ //} val fork = forks.register("folia") { + rootDirectory = upstreamsDirectory().map { it.dir("folia") } upstream.patchDir("paperServer") { upstreamPath = "paper-server" excludes = setOf("src/minecraft", "patches", "build.gradle.kts") @@ -37,7 +_,23 @@ } } - activeFork = fork + val luminol = forks.register("luminol") { + forks = fork + upstream.patchRepo("paperServer") { + upstreamRepo = fork.patchedRepo("paperServer") + patchesDir = rootDirectory.dir("luminol-server/paper-patches") + outputDir = rootDirectory.dir("paper-server") + } + + upstream.patchDir("foliaServer") { + upstreamPath = "folia-server" + excludes = setOf("src/minecraft", "paper-patches", "minecraft-patches", "build.gradle.kts", "build.gradle.kts.patch") + patchesDir = rootDirectory.dir("luminol-server/folia-patches") + outputDir = rootDirectory.dir("folia-server") + } + } + + activeFork = luminol spigot { buildDataRef = "702e1a0a5072b2c4082371d5228cb30525687efc" @@ -123,10 +_,14 @@ main { java { srcDir("../paper-server/src/main/java"); srcDir("../paper-server/src/generated/java") } resources { srcDir("../paper-server/src/main/resources") } + java { srcDir("../folia-server/src/main/java") } + resources { srcDir("../folia-server/src/main/resources") } } test { java { srcDir("../paper-server/src/test/java") } resources { srcDir("../paper-server/src/test/resources") } + java { srcDir("../folia-server/src/test/java") } + resources { srcDir("../folia-server/src/test/resources") } } } val log4jPlugins = sourceSets.create("log4jPlugins") { @@ -153,12 +_,20 @@ } dependencies { - implementation(project(":folia-api")) + implementation(project(":luminol-api")) // Luminol + implementation("com.electronwill.night-config:toml:3.8.2") // Luminol - Night config + // Abomination start + implementation("com.github.luben:zstd-jni:1.5.4-1") + implementation("org.lz4:lz4-java:1.8.0") + implementation("net.openhft:zero-allocation-hashing:0.16") + // Abomination end + implementation("io.github.classgraph:classgraph:4.8.158") // Kaiiju - Entity throttling & Removal implementation("ca.spottedleaf:concurrentutil:0.0.3") implementation("org.jline:jline-terminal-ffm:3.27.1") // use ffm on java 22+ implementation("org.jline:jline-terminal-jni:3.27.1") // fall back to jni on java 21 implementation("net.minecrell:terminalconsoleappender:1.3.0") implementation("net.kyori:adventure-text-serializer-ansi:4.21.0") // Keep in sync with adventureVersion from Paper-API build file + implementation("net.openhft:affinity:3.23.3") // Luminol runtimeConfiguration(sourceSets.main.map { it.runtimeClasspath }) /* @@ -217,26 +_,33 @@ implementation("me.lucko:spark-paper:1.10.133-20250413.112336-1") } +// Pufferfish Start +tasks.withType { + val compilerArgs = options.compilerArgs + compilerArgs.add("--add-modules=jdk.incubator.vector") +} +// Pufferfish End + tasks.jar { manifest { val git = Git(rootProject.layout.projectDirectory.path) val mcVersion = rootProject.providers.gradleProperty("mcVersion").get() val build = System.getenv("BUILD_NUMBER") ?: null - val buildTime = if (build != null) Instant.now() else Instant.EPOCH + val buildTime = Instant.now() // Always use current as build time val gitHash = git.exec(providers, "rev-parse", "--short=7", "HEAD").get().trim() val implementationVersion = "$mcVersion-${build ?: "DEV"}-$gitHash" val date = git.exec(providers, "show", "-s", "--format=%ci", gitHash).get().trim() val gitBranch = git.exec(providers, "rev-parse", "--abbrev-ref", "HEAD").get().trim() attributes( "Main-Class" to "org.bukkit.craftbukkit.Main", - "Implementation-Title" to "Folia", + "Implementation-Title" to "Luminol", "Implementation-Version" to implementationVersion, "Implementation-Vendor" to date, - "Specification-Title" to "Folia", + "Specification-Title" to "Luminol", "Specification-Version" to project.version, - "Specification-Vendor" to "Paper Team", - "Brand-Id" to "papermc:folia", - "Brand-Name" to "Folia", + "Specification-Vendor" to "Luminol Team", + "Brand-Id" to "luminolmc:luminol", + "Brand-Name" to "Luminol", "Build-Number" to (build ?: ""), "Build-Time" to buildTime.toString(), "Git-Branch" to gitBranch, @@ -393,3 +_,10 @@ classpath(tasks.createReobfPaperclipJar.flatMap { it.outputZip }) mainClass.set(null as String?) } + +// Pufferfish Start +tasks.withType { + val compilerArgs = options.compilerArgs + compilerArgs.add("--add-modules=jdk.incubator.vector") +} +// Pufferfish End