WorldEdit/worldedit-fabric/build.gradle.kts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

156 lines
5.1 KiB
Plaintext
Raw Normal View History

2019-07-11 08:29:43 +08:00
import com.github.jengelman.gradle.plugins.shadow.tasks.ShadowJar
import net.fabricmc.loom.api.LoomGradleExtensionAPI
2019-07-11 08:29:43 +08:00
import net.fabricmc.loom.task.RemapJarTask
2020-04-10 10:29:10 +08:00
buildscript {
repositories {
mavenCentral()
maven {
name = "Fabric"
url = uri("https://maven.fabricmc.net/")
}
}
dependencies {
classpath("net.fabricmc:fabric-loom:${versions.loom}")
}
}
2021-11-19 04:16:26 +08:00
applyPlatformAndCoreConfiguration(javaRelease = 17)
2019-07-11 08:29:43 +08:00
applyShadowConfiguration()
apply(plugin = "fabric-loom")
apply(plugin = "java-library")
2019-07-11 08:29:43 +08:00
2023-06-08 12:16:40 +08:00
val minecraftVersion = "1.20"
val loaderVersion = "0.14.21"
2019-07-11 08:29:43 +08:00
val fabricApiConfiguration: Configuration = configurations.create("fabricApi")
configure<LoomGradleExtensionAPI> {
accessWidenerPath.set(project.file("src/main/resources/worldedit.accesswidener"))
}
repositories {
maven {
name = "Fabric"
url = uri("https://maven.fabricmc.net/")
}
getByName("Mojang") {
content {
includeGroupByRegex("com\\.mojang\\..*")
}
}
}
2019-07-11 08:29:43 +08:00
dependencies {
"api"(project(":worldedit-core"))
"implementation"(platform("org.apache.logging.log4j:log4j-bom:${Versions.LOG4J}") {
because("Mojang provides Log4J")
})
2019-07-11 08:29:43 +08:00
"minecraft"("com.mojang:minecraft:$minecraftVersion")
"mappings"(project.the<LoomGradleExtensionAPI>().officialMojangMappings())
"modImplementation"("net.fabricmc:fabric-loader:$loaderVersion")
2019-07-11 08:29:43 +08:00
// [1] declare fabric-api dependency...
"fabricApi"("net.fabricmc.fabric-api:fabric-api:0.83.0+1.20")
// [2] Load the API dependencies from the fabric mod json...
@Suppress("UNCHECKED_CAST")
val fabricModJson = file("src/main/resources/fabric.mod.json").bufferedReader().use {
groovy.json.JsonSlurper().parse(it) as Map<String, Map<String, *>>
}
val wantedDependencies = (fabricModJson["depends"] ?: error("no depends in fabric.mod.json")).keys
.filter { it == "fabric-api-base" || it.contains(Regex("v\\d$")) }
.map { "net.fabricmc.fabric-api:$it" }
2022-03-01 14:55:50 +08:00
.toSet()
logger.lifecycle("Looking for these dependencies:")
for (wantedDependency in wantedDependencies) {
logger.lifecycle(wantedDependency)
}
// [3] and now we resolve it to pick out what we want :D
val fabricApiDependencies = fabricApiConfiguration.incoming.resolutionResult.allDependencies
.onEach {
if (it is UnresolvedDependencyResult) {
throw kotlin.IllegalStateException("Failed to resolve Fabric API", it.failure)
}
}
.filterIsInstance<ResolvedDependencyResult>()
// pick out transitive dependencies
.flatMap {
it.selected.dependencies
}
// grab the requested versions
.map { it.requested }
.filterIsInstance<ModuleComponentSelector>()
// map to standard notation
.associateByTo(
mutableMapOf(),
keySelector = { "${it.group}:${it.module}" },
valueTransform = { "${it.group}:${it.module}:${it.version}" }
)
fabricApiDependencies.keys.retainAll(wantedDependencies)
// sanity check
for (wantedDep in wantedDependencies) {
check(wantedDep in fabricApiDependencies) { "Fabric API library $wantedDep is missing!" }
}
fabricApiDependencies.values.forEach {
2019-09-20 09:11:23 +08:00
"include"(it)
"modImplementation"(it)
}
2019-07-11 08:29:43 +08:00
// No need for this at runtime
"modCompileOnly"("me.lucko:fabric-permissions-api:0.1-SNAPSHOT")
// Hook these up manually, because Fabric doesn't seem to quite do it properly.
"compileOnly"("net.fabricmc:sponge-mixin:${project.versions.mixin}")
"annotationProcessor"("net.fabricmc:sponge-mixin:${project.versions.mixin}")
"annotationProcessor"("net.fabricmc:fabric-loom:${project.versions.loom}")
// Silence some warnings, since apparently this isn't on the compile classpath like it should be.
2022-03-01 14:55:50 +08:00
"compileOnly"("com.google.errorprone:error_prone_annotations:2.11.0")
2019-07-11 08:29:43 +08:00
}
configure<BasePluginExtension> {
archivesName.set("${project.name}-mc$minecraftVersion")
2019-07-11 08:29:43 +08:00
}
configure<PublishingExtension> {
publications.named<MavenPublication>("maven") {
artifactId = the<BasePluginExtension>().archivesName.get()
from(components["java"])
}
}
2019-07-11 08:29:43 +08:00
tasks.named<Copy>("processResources") {
// this will ensure that this task is redone when the versions change.
inputs.property("version", project.ext["internalVersion"])
filesMatching("fabric.mod.json") {
this.expand("version" to project.ext["internalVersion"])
2019-07-11 08:29:43 +08:00
}
}
addJarManifest(WorldEditKind.Mod, includeClasspath = true)
2019-07-11 08:29:43 +08:00
tasks.named<ShadowJar>("shadowJar") {
archiveClassifier.set("dist-dev")
dependencies {
2019-10-19 15:48:49 +08:00
relocate("org.antlr.v4", "com.sk89q.worldedit.antlr4")
2019-07-11 08:29:43 +08:00
2019-10-19 15:48:49 +08:00
include(dependency("org.antlr:antlr4-runtime"))
2019-07-11 08:29:43 +08:00
}
}
2019-09-20 09:11:23 +08:00
tasks.register<RemapJarTask>("remapShadowJar") {
val shadowJar = tasks.getByName<ShadowJar>("shadowJar")
dependsOn(shadowJar)
2022-03-01 14:55:50 +08:00
inputFile.set(shadowJar.archiveFile)
2019-09-20 09:11:23 +08:00
archiveFileName.set(shadowJar.archiveFileName.get().replace(Regex("-dev\\.jar$"), ".jar"))
addNestedDependencies.set(true)
2019-07-11 08:29:43 +08:00
}
tasks.named("assemble").configure {
dependsOn("remapShadowJar")
}