ExampleMod-kts/build.gradle.kts

192 lines
7.3 KiB
Plaintext

import java.text.SimpleDateFormat
import java.util.Date
plugins {
id("maven-publish")
id("net.minecraftforge.gradle") version "5.1.+"
java
}
version = "1.0"
group = "com.yourname.modid" // http://maven.apache.org/guides/mini/guide-naming-conventions.html
project.ext.set("archivesBaseName", "modid")
// Mojang ships Java 17 to end users in 1.18+, so your mod should target Java 17.
java.toolchain.languageVersion.set(JavaLanguageVersion.of(8))
println(
"Java: ${System.getProperty("java.version")}, JVM: ${System.getProperty("java.vm.version")} (${
System.getProperty(
"java.vendor"
)
}), Arch: ${System.getProperty("os.arch")}"
)
minecraft {
// The mappings can be changed at any time and must be in the following format.
// Channel: Version:
// official MCVersion Official field/method names from Mojang mapping files
// parchment YYYY.MM.DD-MCVersion Open community-sourced parameter names and javadocs layered on top of official
//
// You must be aware of the Mojang license when using the "official" or "parchment" mappings.
// See more information here: https://github.com/MinecraftForge/MCPConfig/blob/master/Mojang.md
//
// for legacy minecraft, see also: https://maven.minecraftforge.net/de/oceanlabs/mcp/versions.json
//
// Parchment is an unofficial project maintained by ParchmentMC, separate from MinecraftForge
// Additional setup is needed to use their mappings: https://parchmentmc.org/docs/getting-started
//
// Use non-default mappings at your own risk. They may not always work.
// Simply re-run your setup task after changing the mappings to update your workspace.
mappings("stable", "39-1.12")
// setAccessTransformer(file("src/main/resources/META-INF/accesstransformer.cfg")) // Currently, this location cannot be changed from the default.
// Default run configurations.
// These can be tweaked, removed, or duplicated as needed.
runs {
create("client") {
workingDirectory(project.file("run"))
// Recommended logging data for a userdev environment
// The markers can be added/remove as needed separated by commas.
// "SCAN": For mods scan.
// "REGISTRIES": For firing of registry events.
// "REGISTRYDUMP": For getting the contents of all registries.
property("forge.logging.markers", "REGISTRIES")
// Recommended logging level for the console
// You can set various levels here.
// Please read: https://stackoverflow.com/questions/2031163/when-to-use-the-different-log-levels
property("forge.logging.console.level", "debug")
// Comma-separated list of namespaces to load gametests from. Empty = all namespaces.
property("forge.enabledGameTestNamespaces", "examplemod")
mods {
create("examplemod") {
source(sourceSets.main.get())
}
}
}
create("server") {
workingDirectory(project.file("run"))
property("forge.logging.markers", "REGISTRIES")
property("forge.logging.console.level", "debug")
property("forge.enabledGameTestNamespaces", "examplemod")
mods {
create("examplemod") {
source(sourceSets.main.get())
}
}
}
// This run config launches GameTestServer and runs all registered gametests, then exits.
// By default, the server will crash when no gametests are provided.
// The gametest system is also enabled by default for other run configs under the /test command.
create("gameTestServer") {
workingDirectory(project.file("run"))
property("forge.logging.markers", "REGISTRIES")
property("forge.logging.console.level", "debug")
property("forge.enabledGameTestNamespaces", "examplemod")
mods {
create("examplemod") {
source(sourceSets.main.get())
}
}
}
create("data") {
workingDirectory(project.file("run"))
property("forge.logging.markers", "REGISTRIES")
property("forge.logging.console.level", "debug")
// Specify the modid for data generation, where to output the resulting resource, and where to look for existing resources.
args("--mod", "examplemod", "--all", "--output", file("src/generated/resources/"), "--existing", file("src/main/resources/"))
mods {
create("examplemod") {
source(sourceSets.main.get())
}
}
}
}
}
// Include resources generated by data generators.
sourceSets.main.get().resources { srcDir("src/generated/resources") }
repositories {
// Put repositories for dependencies here
// ForgeGradle automatically adds the Forge maven and Maven Central for you
// If you have mod jar dependencies in ./libs, you can declare them as a repository like so:
// flatDir {
// dir "libs"
// }
}
dependencies {
// Specify the version of Minecraft to use. If this is any group other than "net.minecraft", it is assumed
// that the dep is a ForgeGradle "patcher" dependency, and its patches will be applied.
// The userdev artifact is a special name and will get all sorts of transformations applied to it.
minecraft("net.minecraftforge:forge:1.12.2-14.23.5.2860")
// Real mod deobf dependency examples - these get remapped to your current mappings
// implementation fg.deobf("com.tterrag.registrate:Registrate:MC${mc_version}-${registrate_version}") // Adds registrate as a dependency
// Examples using mod jars from ./libs
// implementation fg.deobf("blank:coolmod-${mc_version}:${coolmod_version}")
// For more info...
// http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html
// http://www.gradle.org/docs/current/userguide/dependency_management.html
}
// Example for how to get properties into the manifest for reading at runtime.
tasks.jar {
manifest {
attributes(
"Specification-Title" to "examplemod",
"Specification-Vendor" to "examplemodsareus",
"Specification-Version" to "1", // We are version 1 of ourselves
"Implementation-Title" to project.name,
"Implementation-Version" to project.tasks.jar.get().archiveVersion,
"Implementation-Vendor" to "examplemodsareus",
"Implementation-Timestamp" to SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ssZ").format(Date())
)
}
}
// Example configuration to allow publishing using the maven-publish plugin
// This is the preferred method to reobfuscate your jar file
tasks.jar.get().finalizedBy("reobfJar")
// However if you are in a multi-project build, dev time needs unobfed jar files, so you can delay the obfuscation until publishing by doing
tasks.publish.get().dependsOn("reobfJar")
publishing {
publications {
create<MavenPublication>("mavenJava") {
artifact(tasks.jar)
}
}
repositories {
maven("file://${project.projectDir}/mcmodsrepo")
}
}
tasks.withType<JavaCompile> {
options.encoding = "UTF-8" // Use the UTF-8 charset for Java compilation
}