192 lines
7.3 KiB
Plaintext
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
|
|
} |