mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-14 05:33:56 +01:00
Move to paperweight v2
Co-authored-by: Nassim Jahnke <nassim@njahnke.dev>
This commit is contained in:
parent
4ea25cd504
commit
40ec8fb606
8 changed files with 87 additions and 121 deletions
24
.gitignore
vendored
24
.gitignore
vendored
|
@ -28,20 +28,6 @@ bin/
|
||||||
dist/
|
dist/
|
||||||
manifest.mf
|
manifest.mf
|
||||||
|
|
||||||
/work/Temp/
|
|
||||||
work/1.*
|
|
||||||
work/Minecraft
|
|
||||||
work/BuildData
|
|
||||||
work/Bukkit
|
|
||||||
work/CraftBukkit
|
|
||||||
work/Paperclip
|
|
||||||
work/Spigot
|
|
||||||
work/Spigot-Server
|
|
||||||
work/Spigot-API
|
|
||||||
work/*.jar
|
|
||||||
work/test-server
|
|
||||||
work/ForgeFlower
|
|
||||||
|
|
||||||
# Mac filesystem dust
|
# Mac filesystem dust
|
||||||
.DS_Store/
|
.DS_Store/
|
||||||
.DS_Store
|
.DS_Store
|
||||||
|
@ -63,14 +49,10 @@ out/
|
||||||
run/
|
run/
|
||||||
logs/
|
logs/
|
||||||
|
|
||||||
Paper-Server
|
|
||||||
Paper-API
|
|
||||||
Paperclip.jar
|
|
||||||
paperclip.jar
|
|
||||||
paperclip-*.jar
|
|
||||||
paperclip.properties
|
|
||||||
|
|
||||||
!gradle/wrapper/gradle-wrapper.jar
|
!gradle/wrapper/gradle-wrapper.jar
|
||||||
|
|
||||||
test-plugin.settings.gradle.kts
|
test-plugin.settings.gradle.kts
|
||||||
paper-api-generator.settings.gradle.kts
|
paper-api-generator.settings.gradle.kts
|
||||||
|
|
||||||
|
# Don't track patched vanilla submodules
|
||||||
|
paper-server/src/vanilla/
|
||||||
|
|
|
@ -11,7 +11,7 @@ import kotlin.io.path.*
|
||||||
plugins {
|
plugins {
|
||||||
java
|
java
|
||||||
`maven-publish`
|
`maven-publish`
|
||||||
id("io.papermc.paperweight.core") version "1.7.7"
|
id("io.papermc.paperweight.core") version "2.0.0-SNAPSHOT"
|
||||||
}
|
}
|
||||||
|
|
||||||
allprojects {
|
allprojects {
|
||||||
|
@ -53,59 +53,21 @@ subprojects {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
val spigotDecompiler: Configuration by configurations.creating
|
|
||||||
|
|
||||||
repositories {
|
|
||||||
mavenCentral()
|
|
||||||
maven(paperMavenPublicUrl) {
|
|
||||||
content {
|
|
||||||
onlyForConfigurations(
|
|
||||||
configurations.paperclip.name,
|
|
||||||
spigotDecompiler.name,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
paramMappings("net.fabricmc:yarn:1.21.4+build.1:mergedv2")
|
mache("io.papermc:mache:1.21.4+build.3")
|
||||||
remapper("net.fabricmc:tiny-remapper:0.10.3:fat")
|
|
||||||
decompiler("org.vineflower:vineflower:1.10.1")
|
|
||||||
spigotDecompiler("io.papermc:patched-spigot-fernflower:0.1+build.13")
|
|
||||||
paperclip("io.papermc:paperclip:3.0.3")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
paperweight {
|
paperweight {
|
||||||
minecraftVersion = providers.gradleProperty("mcVersion")
|
softSpoon = true
|
||||||
serverProject = project(":paper-server")
|
minecraftVersion = "1.21.4"
|
||||||
|
// macheOldPath = file("F:\\Projects\\PaperTooling\\mache\\versions\\1.21.4\\src\\main\\java")
|
||||||
paramMappingsRepo = paperMavenPublicUrl
|
// gitFilePatches = true
|
||||||
remapRepo = paperMavenPublicUrl
|
|
||||||
decompileRepo = paperMavenPublicUrl
|
|
||||||
|
|
||||||
craftBukkit {
|
|
||||||
fernFlowerJar = layout.file(spigotDecompiler.elements.map { it.single().asFile })
|
|
||||||
}
|
|
||||||
|
|
||||||
paper {
|
paper {
|
||||||
spigotApiPatchDir = layout.projectDirectory.dir("patches/api")
|
paperServerDir = file("paper-server")
|
||||||
spigotServerPatchDir = layout.projectDirectory.dir("patches/server")
|
|
||||||
|
|
||||||
mappingsPatch = layout.projectDirectory.file("build-data/mappings-patch.tiny")
|
|
||||||
reobfMappingsPatch = layout.projectDirectory.file("build-data/reobf-mappings-patch.tiny")
|
|
||||||
|
|
||||||
reobfPackagesToFix.addAll(
|
|
||||||
"co.aikar.timings",
|
|
||||||
"com.destroystokyo.paper",
|
|
||||||
"com.mojang",
|
|
||||||
"io.papermc.paper",
|
|
||||||
"ca.spottedleaf",
|
|
||||||
"net.kyori.adventure.bossbar",
|
|
||||||
"net.minecraft",
|
|
||||||
"org.bukkit.craftbukkit",
|
|
||||||
"org.spigotmc",
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
serverProject = project(":paper-server")
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.generateDevelopmentBundle {
|
tasks.generateDevelopmentBundle {
|
||||||
|
|
3
paper-server/.gitignore
vendored
3
paper-server/.gitignore
vendored
|
@ -40,9 +40,6 @@ dependency-reduced-pom.xml
|
||||||
*.iws
|
*.iws
|
||||||
.idea/
|
.idea/
|
||||||
|
|
||||||
/src/main/resources/achievement
|
|
||||||
/src/main/resources/lang
|
|
||||||
|
|
||||||
# vs code
|
# vs code
|
||||||
/.vscode
|
/.vscode
|
||||||
/.factorypath
|
/.factorypath
|
||||||
|
|
|
@ -78,9 +78,6 @@ dependencies {
|
||||||
// Paper end - spark
|
// Paper end - spark
|
||||||
}
|
}
|
||||||
|
|
||||||
paperweight {
|
|
||||||
craftBukkitPackageVersion.set("v1_21_R3") // also needs to be updated in MappingEnvironment
|
|
||||||
}
|
|
||||||
|
|
||||||
tasks.jar {
|
tasks.jar {
|
||||||
archiveClassifier.set("dev")
|
archiveClassifier.set("dev")
|
||||||
|
@ -107,7 +104,6 @@ tasks.jar {
|
||||||
"Build-Time" to Instant.now().toString(),
|
"Build-Time" to Instant.now().toString(),
|
||||||
"Git-Branch" to gitBranch, // Paper
|
"Git-Branch" to gitBranch, // Paper
|
||||||
"Git-Commit" to gitHash, // Paper
|
"Git-Commit" to gitHash, // Paper
|
||||||
"CraftBukkit-Package-Version" to paperweight.craftBukkitPackageVersion.get(), // Paper
|
|
||||||
)
|
)
|
||||||
for (tld in setOf("net", "com", "org")) {
|
for (tld in setOf("net", "com", "org")) {
|
||||||
attributes("$tld/bukkit", "Sealed" to true)
|
attributes("$tld/bukkit", "Sealed" to true)
|
||||||
|
@ -127,27 +123,27 @@ publishing {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Paper start
|
// Paper start
|
||||||
val scanJar = tasks.register("scanJarForBadCalls", io.papermc.paperweight.tasks.ScanJarForBadCalls::class) {
|
// val scanJar = tasks.register("scanJarForBadCalls", io.papermc.paperweight.tasks.ScanJarForBadCalls::class) {
|
||||||
badAnnotations.add("Lio/papermc/paper/annotation/DoNotUse;")
|
// badAnnotations.add("Lio/papermc/paper/annotation/DoNotUse;")
|
||||||
jarToScan.set(tasks.serverJar.flatMap { it.archiveFile })
|
// jarToScan.set(tasks.serverJar.flatMap { it.archiveFile })
|
||||||
classpath.from(configurations.compileClasspath)
|
// classpath.from(configurations.compileClasspath)
|
||||||
}
|
// }
|
||||||
tasks.check {
|
// tasks.check {
|
||||||
dependsOn(scanJar)
|
// dependsOn(scanJar)
|
||||||
}
|
// }
|
||||||
// Paper end
|
// Paper end
|
||||||
// Paper start - use TCA for console improvements
|
// Paper start - use TCA for console improvements
|
||||||
tasks.serverJar {
|
// tasks.serverJar {
|
||||||
from(alsoShade.elements.map {
|
// from(alsoShade.elements.map {
|
||||||
it.map { f ->
|
// it.map { f ->
|
||||||
if (f.asFile.isFile) {
|
// if (f.asFile.isFile) {
|
||||||
zipTree(f.asFile)
|
// zipTree(f.asFile)
|
||||||
} else {
|
// } else {
|
||||||
f.asFile
|
// f.asFile
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
})
|
// })
|
||||||
}
|
// }
|
||||||
// Paper end - use TCA for console improvements
|
// Paper end - use TCA for console improvements
|
||||||
|
|
||||||
tasks.test {
|
tasks.test {
|
||||||
|
@ -204,22 +200,22 @@ fun TaskContainer.registerRunTask(
|
||||||
block(this)
|
block(this)
|
||||||
}
|
}
|
||||||
|
|
||||||
val runtimeClasspathWithoutVanillaServer = configurations.runtimeClasspath.flatMap { it.elements }
|
// val runtimeClasspathWithoutVanillaServer = configurations.runtimeClasspath.flatMap { it.elements }
|
||||||
.zip(configurations.vanillaServer.map { it.singleFile.absolutePath }) { runtime, vanilla ->
|
// .zip(configurations.vanillaServer.map { it.singleFile.absolutePath }) { runtime, vanilla ->
|
||||||
runtime.filterNot { it.asFile.absolutePath == vanilla }
|
// runtime.filterNot { it.asFile.absolutePath == vanilla }
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
tasks.registerRunTask("runServer") {
|
// tasks.registerRunTask("runServer") {
|
||||||
description = "Spin up a test server from the Mojang mapped server jar"
|
// description = "Spin up a test server from the Mojang mapped server jar"
|
||||||
classpath(tasks.includeMappings.flatMap { it.outputJar })
|
// classpath(tasks.includeMappings.flatMap { it.outputJar })
|
||||||
classpath(runtimeClasspathWithoutVanillaServer)
|
// classpath(runtimeClasspathWithoutVanillaServer)
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
tasks.registerRunTask("runReobfServer") {
|
// tasks.registerRunTask("runReobfServer") {
|
||||||
description = "Spin up a test server from the reobfJar output jar"
|
// description = "Spin up a test server from the reobfJar output jar"
|
||||||
classpath(tasks.reobfJar.flatMap { it.outputJar })
|
// classpath(tasks.reobfJar.flatMap { it.outputJar })
|
||||||
classpath(runtimeClasspathWithoutVanillaServer)
|
// classpath(runtimeClasspathWithoutVanillaServer)
|
||||||
}
|
// }
|
||||||
|
|
||||||
tasks.registerRunTask("runDevServer") {
|
tasks.registerRunTask("runDevServer") {
|
||||||
description = "Spin up a test server without assembling a jar"
|
description = "Spin up a test server without assembling a jar"
|
||||||
|
@ -232,18 +228,18 @@ tasks.registerRunTask("runBundler") {
|
||||||
classpath(rootProject.tasks.named<io.papermc.paperweight.tasks.CreateBundlerJar>("createMojmapBundlerJar").flatMap { it.outputZip })
|
classpath(rootProject.tasks.named<io.papermc.paperweight.tasks.CreateBundlerJar>("createMojmapBundlerJar").flatMap { it.outputZip })
|
||||||
mainClass.set(null as String?)
|
mainClass.set(null as String?)
|
||||||
}
|
}
|
||||||
tasks.registerRunTask("runReobfBundler") {
|
// tasks.registerRunTask("runReobfBundler") {
|
||||||
description = "Spin up a test server from the reobf bundler jar"
|
// description = "Spin up a test server from the reobf bundler jar"
|
||||||
classpath(rootProject.tasks.named<io.papermc.paperweight.tasks.CreateBundlerJar>("createReobfBundlerJar").flatMap { it.outputZip })
|
// classpath(rootProject.tasks.named<io.papermc.paperweight.tasks.CreateBundlerJar>("createReobfBundlerJar").flatMap { it.outputZip })
|
||||||
mainClass.set(null as String?)
|
// mainClass.set(null as String?)
|
||||||
}
|
// }
|
||||||
tasks.registerRunTask("runPaperclip") {
|
tasks.registerRunTask("runPaperclip") {
|
||||||
description = "Spin up a test server from the Mojang mapped Paperclip jar"
|
description = "Spin up a test server from the Mojang mapped Paperclip jar"
|
||||||
classpath(rootProject.tasks.named<io.papermc.paperweight.tasks.CreatePaperclipJar>("createMojmapPaperclipJar").flatMap { it.outputZip })
|
classpath(rootProject.tasks.named<io.papermc.paperweight.tasks.CreatePaperclipJar>("createMojmapPaperclipJar").flatMap { it.outputZip })
|
||||||
mainClass.set(null as String?)
|
mainClass.set(null as String?)
|
||||||
}
|
}
|
||||||
tasks.registerRunTask("runReobfPaperclip") {
|
// tasks.registerRunTask("runReobfPaperclip") {
|
||||||
description = "Spin up a test server from the reobf Paperclip jar"
|
// description = "Spin up a test server from the reobf Paperclip jar"
|
||||||
classpath(rootProject.tasks.named<io.papermc.paperweight.tasks.CreatePaperclipJar>("createReobfPaperclipJar").flatMap { it.outputZip })
|
// classpath(rootProject.tasks.named<io.papermc.paperweight.tasks.CreatePaperclipJar>("createReobfPaperclipJar").flatMap { it.outputZip })
|
||||||
mainClass.set(null as String?)
|
// mainClass.set(null as String?)
|
||||||
}
|
// }
|
||||||
|
|
0
paper-server/patches/features/.gitkeep
Normal file
0
paper-server/patches/features/.gitkeep
Normal file
|
@ -33,7 +33,7 @@ if (!file(".git").exists()) {
|
||||||
|
|
||||||
rootProject.name = "paper"
|
rootProject.name = "paper"
|
||||||
|
|
||||||
for (name in listOf("Paper-API", "Paper-Server")) {
|
for (name in listOf("paper-api", "paper-server")) {
|
||||||
val projName = name.lowercase(Locale.ENGLISH)
|
val projName = name.lowercase(Locale.ENGLISH)
|
||||||
include(projName)
|
include(projName)
|
||||||
file(name).mkdirs()
|
file(name).mkdirs()
|
||||||
|
|
5
softspoon/.gitignore
vendored
Normal file
5
softspoon/.gitignore
vendored
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
buildtools
|
||||||
|
spigot-mapped
|
||||||
|
spigot-decomp
|
||||||
|
vine-decomp
|
||||||
|
vineflower.jar
|
24
softspoon/setup.sh
Normal file
24
softspoon/setup.sh
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
mkdir "buildtools" || true
|
||||||
|
(
|
||||||
|
cd buildtools || exit
|
||||||
|
wget https://hub.spigotmc.org/jenkins/job/BuildTools/lastSuccessfulBuild/artifact/target/BuildTools.jar
|
||||||
|
#java -jar BuildTools.jar --rev 4369 # random 1.21.3 version
|
||||||
|
)
|
||||||
|
|
||||||
|
echo "copying spigot-mapped"
|
||||||
|
mkdir "spigot-mapped" || true
|
||||||
|
cp -r buildtools/work/decompile-7331f017/classes spigot-mapped
|
||||||
|
|
||||||
|
echo "copying spigot-decomp"
|
||||||
|
mkdir "spigot-decomp" || true
|
||||||
|
cp -r buildtools/work/decompile-7331f017/net spigot-decomp/net
|
||||||
|
|
||||||
|
echo "making vine-decomp"
|
||||||
|
mkdir "vine-decomp" || true
|
||||||
|
wget https://s01.oss.sonatype.org/content/repositories/snapshots/org/vineflower/vineflower/1.11.0-SNAPSHOT/vineflower-1.11.0-20240911.205325-50.jar -O vineflower.jar
|
||||||
|
# todo double check vineflower version and arguments, rn this is mache stuff
|
||||||
|
java -jar vineflower.jar --synthetic-not-set=true --ternary-constant-simplification=true --include-runtime=current --decompile-complex-constant-dynamic=true --indent-string=" " --decompile-inner=true --remove-bridge=true --decompile-generics=true --ascii-strings=false --remove-synthetic=true --include-classpath=true --inline-simple-lambdas=true --ignore-invalid-bytecode=false --bytecode-source-mapping=true --dump-code-lines=true --override-annotation=false --skip-extra-files=true spigot-mapped/classes vine-decomp
|
||||||
|
|
||||||
|
# todo spigot and vf decompile a paper (old) remapped jar (just steal from some paper project cache folder)
|
Loading…
Reference in a new issue