quilt-kotlin-template-mod/build.gradle.kts
2023-10-17 23:01:05 -07:00

141 lines
4 KiB
Text

// This is to suppress false warnings generated by a bug in IntelliJ
@file:Suppress("DSL_SCOPE_VIOLATION", "MISSING_DEPENDENCY_CLASS", "FUNCTION_CALL_EXPECTED", "PropertyName")
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
plugins {
java
`maven-publish`
alias(libs.plugins.kotlin)
alias(libs.plugins.quilt.loom)
}
val archives_base_name: String by project
base.archivesName.set(archives_base_name)
val javaVersion = 17
repositories {
// Add repositories to retrieve artifacts from in here.
// You should only use this when depending on other mods because
// Loom adds the essential maven repositories to download Minecraft and libraries from automatically.
// See https://docs.gradle.org/current/userguide/declaring_repositories.html
// for more information about repositories.
}
// All the dependencies are declared at gradle/libs.version.toml and referenced with "libs.<id>"
// See https://docs.gradle.org/current/userguide/platforms.html for information on how version catalogs work.
dependencies {
minecraft(libs.minecraft)
mappings(
variantOf(libs.quilt.mappings) {
classifier("intermediary-v2")
}
)
// Replace the above line with the block below if you want to use Mojang mappings as your primary mappings, falling back on QM for parameters and Javadocs
/*
mappings(
loom.layered {
mappings(variantOf(libs.quilt.mappings) { classifier("intermediary-v2") })
officialMojangMappings()
}
)
*/
modImplementation(libs.quilt.loader)
// QSL is not a complete API; You will need Quilted Fabric API to fill in the gaps.
// Quilted Fabric API will automatically pull in the correct QSL version.
modImplementation(libs.quilted.fabric.api)
// modImplementation(libs.bundles.quilted.fabric.api.deprecated) // If you wish to use the deprecated Fabric API modules
modImplementation(libs.quilted.kotlin.api)
}
tasks {
withType<KotlinCompile> {
kotlinOptions {
jvmTarget = javaVersion.toString()
// languageVersion: A.B of the kotlin plugin version A.B.C
languageVersion = libs.plugins.kotlin.get().version.requiredVersion.substringBeforeLast('.')
}
}
withType<JavaCompile>.configureEach {
options.encoding = "UTF-8"
options.isDeprecation = true
options.release.set(javaVersion)
}
processResources {
filteringCharset = "UTF-8"
inputs.property("version", project.version)
filesMatching("quilt.mod.json") {
expand(
mapOf(
"version" to project.version
)
)
}
}
javadoc {
options.encoding = "UTF-8"
}
// Run `./gradlew wrapper --gradle-version <newVersion>` or `gradle wrapper --gradle-version <newVersion>` to update gradle scripts
// BIN distribution should be sufficient for the majority of mods
wrapper {
distributionType = Wrapper.DistributionType.BIN
}
jar {
from("LICENSE") {
rename { "LICENSE_${archives_base_name}" }
}
}
}
val targetJavaVersion = JavaVersion.toVersion(javaVersion)
if (JavaVersion.current() < targetJavaVersion) {
kotlin.jvmToolchain(javaVersion)
java.toolchain {
languageVersion.set(JavaLanguageVersion.of(javaVersion))
}
}
java {
// Loom will automatically attach sourcesJar to a RemapSourcesJar task and to the "build" task if it is present.
// If you remove this line, sources will not be generated.
withSourcesJar()
// If this mod is going to be a library, then it should also generate Javadocs in order to aid with development.
// Uncomment this line to generate them.
// withJavadocJar()
// Still required by IDEs such as Eclipse and VSC
sourceCompatibility = targetJavaVersion
targetCompatibility = targetJavaVersion
}
// Configure the maven publication
publishing {
publications {
register<MavenPublication>("Maven") {
from(components.getByName("java"))
}
}
// See https://docs.gradle.org/current/userguide/publishing_maven.html for information on how to set up publishing.
repositories {
// Add repositories to publish to here.
// Notice: This block does NOT have the same function as the block in the top level.
// The repositories here will be used for publishing your artifact, not for
// retrieving dependencies.
}
}