forked from SteamWar/SteamWar
Extract widener definition into a widener.gradle.kts plugin
This commit is contained in:
@@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
plugins {
|
plugins {
|
||||||
steamwar.java
|
steamwar.java
|
||||||
|
widener
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.compileJava {
|
tasks.compileJava {
|
||||||
@@ -30,45 +31,6 @@ java {
|
|||||||
targetCompatibility = JavaVersion.VERSION_21
|
targetCompatibility = JavaVersion.VERSION_21
|
||||||
}
|
}
|
||||||
|
|
||||||
// ─── Collect all .accesswidener files from this plugin's resources ────────────
|
|
||||||
val accessWidenerFiles: FileCollection = fileTree("src/") {
|
|
||||||
include("**/*.accesswidener")
|
|
||||||
}
|
|
||||||
|
|
||||||
val paperJarProvider: Provider<File> = provider {
|
|
||||||
val dep = libs.nms.get()
|
|
||||||
configurations["compileClasspath"].resolvedConfiguration.resolvedArtifacts.first { artifact ->
|
|
||||||
artifact.moduleVersion.id.module.group == dep.module.group && artifact.moduleVersion.id.module.name == dep.module.name
|
|
||||||
}.file
|
|
||||||
}
|
|
||||||
|
|
||||||
// ─── Widen the Paper dev JAR so the IDE / javac see the patched access ────────
|
|
||||||
val widenedJar by tasks.registering(JavaExec::class) {
|
|
||||||
description = "Produces a widened copy of the Paper dev JAR for compile-time use."
|
|
||||||
group = "widener"
|
|
||||||
|
|
||||||
// Re-run whenever the .accesswidener files change
|
|
||||||
inputs.file(paperJarProvider)
|
|
||||||
inputs.files(accessWidenerFiles)
|
|
||||||
|
|
||||||
val output = layout.buildDirectory.file("widened/paper-widened.jar")
|
|
||||||
outputs.file(output)
|
|
||||||
|
|
||||||
classpath = project(":AccessWidener").tasks.named<com.github.jengelman.gradle.plugins.shadow.tasks.ShadowJar>("shadowJar").get().outputs.files
|
|
||||||
|
|
||||||
mainClass.set("de.steamwar.Main")
|
|
||||||
|
|
||||||
doFirst {
|
|
||||||
args = buildList {
|
|
||||||
add(paperJarProvider.get().absolutePath)
|
|
||||||
add(output.get().asFile.absolutePath)
|
|
||||||
addAll(accessWidenerFiles.map { it.absolutePath })
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
dependsOn(":AccessWidener:shadowJar")
|
|
||||||
}
|
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compileOnly(libs.classindex)
|
compileOnly(libs.classindex)
|
||||||
annotationProcessor(libs.classindex)
|
annotationProcessor(libs.classindex)
|
||||||
@@ -79,7 +41,6 @@ dependencies {
|
|||||||
|
|
||||||
compileOnly(libs.paperapi)
|
compileOnly(libs.paperapi)
|
||||||
compileOnly(libs.nms)
|
compileOnly(libs.nms)
|
||||||
compileOnly(files(widenedJar))
|
|
||||||
|
|
||||||
compileOnly(libs.fawe)
|
compileOnly(libs.fawe)
|
||||||
compileOnly(libs.netty)
|
compileOnly(libs.netty)
|
||||||
@@ -88,6 +49,6 @@ dependencies {
|
|||||||
implementation(files("$projectDir/../libs/YAPION-SNAPSHOT.jar"))
|
implementation(files("$projectDir/../libs/YAPION-SNAPSHOT.jar"))
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.compileJava {
|
widener {
|
||||||
dependsOn(widenedJar)
|
fromCatalog(libs.nms)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
plugins {
|
plugins {
|
||||||
steamwar.java
|
steamwar.java
|
||||||
|
widener
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.compileJava {
|
tasks.compileJava {
|
||||||
@@ -42,45 +43,6 @@ tasks.withType<Test>().configureEach {
|
|||||||
jvmArgs("--add-exports", "java.base/jdk.internal.misc=ALL-UNNAMED")
|
jvmArgs("--add-exports", "java.base/jdk.internal.misc=ALL-UNNAMED")
|
||||||
}
|
}
|
||||||
|
|
||||||
// ─── Collect all .accesswidener files from this plugin's resources ────────────
|
|
||||||
val accessWidenerFiles: FileCollection = fileTree("src/") {
|
|
||||||
include("**/*.accesswidener")
|
|
||||||
}
|
|
||||||
|
|
||||||
val paperJarProvider: Provider<File> = provider {
|
|
||||||
val dep = libs.nms.get()
|
|
||||||
configurations["compileClasspath"].resolvedConfiguration.resolvedArtifacts.first { artifact ->
|
|
||||||
artifact.moduleVersion.id.module.group == dep.module.group && artifact.moduleVersion.id.module.name == dep.module.name
|
|
||||||
}.file
|
|
||||||
}
|
|
||||||
|
|
||||||
// ─── Widen the Paper dev JAR so the IDE / javac see the patched access ────────
|
|
||||||
val widenedJar by tasks.registering(JavaExec::class) {
|
|
||||||
description = "Produces a widened copy of the Paper dev JAR for compile-time use."
|
|
||||||
group = "widener"
|
|
||||||
|
|
||||||
// Re-run whenever the .accesswidener files change
|
|
||||||
inputs.file(paperJarProvider)
|
|
||||||
inputs.files(accessWidenerFiles)
|
|
||||||
|
|
||||||
val output = layout.buildDirectory.file("widened/paper-widened.jar")
|
|
||||||
outputs.file(output)
|
|
||||||
|
|
||||||
classpath = project(":AccessWidener").tasks.named<com.github.jengelman.gradle.plugins.shadow.tasks.ShadowJar>("shadowJar").get().outputs.files
|
|
||||||
|
|
||||||
mainClass.set("de.steamwar.Main")
|
|
||||||
|
|
||||||
doFirst {
|
|
||||||
args = buildList {
|
|
||||||
add(paperJarProvider.get().absolutePath)
|
|
||||||
add(output.get().asFile.absolutePath)
|
|
||||||
addAll(accessWidenerFiles.map { it.absolutePath })
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
dependsOn(":AccessWidener:shadowJar")
|
|
||||||
}
|
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compileOnly(libs.classindex)
|
compileOnly(libs.classindex)
|
||||||
annotationProcessor(libs.classindex)
|
annotationProcessor(libs.classindex)
|
||||||
@@ -92,7 +54,6 @@ dependencies {
|
|||||||
|
|
||||||
compileOnly(libs.paperapi)
|
compileOnly(libs.paperapi)
|
||||||
compileOnly(libs.nms)
|
compileOnly(libs.nms)
|
||||||
compileOnly(files(widenedJar))
|
|
||||||
compileOnly(libs.authlib)
|
compileOnly(libs.authlib)
|
||||||
compileOnly(libs.datafixer)
|
compileOnly(libs.datafixer)
|
||||||
compileOnly(libs.netty)
|
compileOnly(libs.netty)
|
||||||
@@ -102,6 +63,6 @@ dependencies {
|
|||||||
implementation(libs.anvilgui)
|
implementation(libs.anvilgui)
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.compileJava {
|
widener {
|
||||||
dependsOn(widenedJar)
|
fromCatalog(libs.nms)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* This file is a part of the SteamWar software.
|
* This file is a part of the SteamWar software.
|
||||||
*
|
*
|
||||||
* Copyright (C) 2025 SteamWar.de-Serverteam
|
* Copyright (C) 2026 SteamWar.de-Serverteam
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU Affero General Public License as published by
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
@@ -18,21 +18,22 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
plugins {
|
plugins {
|
||||||
id 'groovy-gradle-plugin'
|
`kotlin-dsl`
|
||||||
}
|
`groovy-gradle-plugin`
|
||||||
|
|
||||||
sourceSets {
|
|
||||||
main {
|
|
||||||
groovy {
|
|
||||||
srcDirs("src/")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
repositories {
|
repositories {
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
|
gradlePluginPortal()
|
||||||
|
}
|
||||||
|
|
||||||
|
sourceSets {
|
||||||
|
main {
|
||||||
|
groovy.srcDirs("src/main/groovy")
|
||||||
|
kotlin.srcDirs("src/main/kotlin")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
implementation("org.jetbrains.kotlin:kotlin-gradle-plugin:2.2.21")
|
implementation("org.jetbrains.kotlin:kotlin-gradle-plugin:2.2.21")
|
||||||
}
|
}
|
||||||
@@ -0,0 +1,52 @@
|
|||||||
|
/*
|
||||||
|
* This file is a part of the SteamWar software.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2026 SteamWar.de-Serverteam
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import org.gradle.api.Project
|
||||||
|
import org.gradle.api.artifacts.MinimalExternalModuleDependency
|
||||||
|
import org.gradle.api.file.ConfigurableFileCollection
|
||||||
|
import org.gradle.api.provider.Provider
|
||||||
|
import javax.inject.Inject
|
||||||
|
|
||||||
|
abstract class WidenerExtension {
|
||||||
|
|
||||||
|
@get:Inject
|
||||||
|
abstract val project: Project
|
||||||
|
|
||||||
|
abstract val inputJars: ConfigurableFileCollection
|
||||||
|
abstract val accessWidenerFiles: ConfigurableFileCollection
|
||||||
|
|
||||||
|
fun fromCatalog(vararg dependencies: Provider<MinimalExternalModuleDependency>) {
|
||||||
|
val files = dependencies.map { dependency ->
|
||||||
|
project.provider {
|
||||||
|
val dep = dependency.get()
|
||||||
|
|
||||||
|
project.configurations.getByName("compileClasspath")
|
||||||
|
.resolvedConfiguration
|
||||||
|
.resolvedArtifacts
|
||||||
|
.first {
|
||||||
|
it.moduleVersion.id.module.group == dep.module.group &&
|
||||||
|
it.moduleVersion.id.module.name == dep.module.name
|
||||||
|
}
|
||||||
|
.file
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
inputJars.from(files)
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,78 @@
|
|||||||
|
/*
|
||||||
|
* This file is a part of the SteamWar software.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2026 SteamWar.de-Serverteam
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
val widener = extensions.create<WidenerExtension>("widener")
|
||||||
|
|
||||||
|
widener.accessWidenerFiles.setFrom(
|
||||||
|
fileTree("src/") { include("**/*.accesswidener") }
|
||||||
|
)
|
||||||
|
|
||||||
|
// ─── Tasks (unchanged from before) ───────────────────────────────────────────
|
||||||
|
|
||||||
|
val jarWidenerClasspath = rootProject.project(":AccessWidener")
|
||||||
|
.tasks.named("shadowJar")
|
||||||
|
.get().outputs.files
|
||||||
|
|
||||||
|
val allWidenedJars = objects.fileCollection()
|
||||||
|
|
||||||
|
project.gradle.projectsEvaluated {
|
||||||
|
if (widener.inputJars.isEmpty) {
|
||||||
|
logger.warn("[widener] No input JARs configured for ${project.name} — widenedJar tasks will not be registered.")
|
||||||
|
return@projectsEvaluated
|
||||||
|
}
|
||||||
|
|
||||||
|
widener.inputJars.forEachIndexed { index, inputJar ->
|
||||||
|
val taskName = if (index == 0) "widenedJar" else "widenedJar$index"
|
||||||
|
val outputFile = layout.buildDirectory
|
||||||
|
.file("widened/${inputJar.nameWithoutExtension}-widened.jar")
|
||||||
|
|
||||||
|
val task = tasks.register<JavaExec>(taskName) {
|
||||||
|
description = "Produces a widened copy of ${inputJar.name} for compile-time use."
|
||||||
|
group = "widener"
|
||||||
|
|
||||||
|
inputs.file(inputJar)
|
||||||
|
inputs.files(widener.accessWidenerFiles)
|
||||||
|
outputs.file(outputFile)
|
||||||
|
|
||||||
|
classpath = jarWidenerClasspath
|
||||||
|
mainClass.set("de.steamwar.Main")
|
||||||
|
|
||||||
|
dependsOn(rootProject.project(":AccessWidener").tasks.named("shadowJar"))
|
||||||
|
|
||||||
|
doFirst {
|
||||||
|
args = buildList {
|
||||||
|
add(inputJar.absolutePath)
|
||||||
|
add(outputFile.get().asFile.absolutePath)
|
||||||
|
addAll(widener.accessWidenerFiles.map { it.absolutePath })
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
allWidenedJars.from(task)
|
||||||
|
}
|
||||||
|
|
||||||
|
tasks.named("compileJava") {
|
||||||
|
// dependsOn(allWidenedJars.buildDependencies)
|
||||||
|
dependsOn(allWidenedJars)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
project.dependencies {
|
||||||
|
add("compileOnly", project.fileTree("build/widened"))
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user