|
|
|
plugins {
|
|
|
|
id 'fabric-loom' version '0.8-SNAPSHOT'
|
|
|
|
id 'maven-publish'
|
|
|
|
}
|
|
|
|
|
|
|
|
sourceCompatibility = JavaVersion.VERSION_16
|
|
|
|
targetCompatibility = JavaVersion.VERSION_16
|
|
|
|
|
|
|
|
archivesBaseName = project.archives_base_name
|
|
|
|
group = project.maven_group
|
|
|
|
|
|
|
|
// Obtains mod version. change file reference if your fabric.mod.json is located elsewhere
|
|
|
|
import groovy.json.JsonSlurper
|
|
|
|
version = new JsonSlurper().parse(file('src/main/resources/fabric.mod.json')).version
|
|
|
|
|
|
|
|
// You can use logger.lifecycle to print out messages like System.out; double-quote strings convert
|
|
|
|
// ${statement} templates to statement values, such as method calls, while single-quote strings don't.
|
|
|
|
// getXxx() calls can be simplified to xxx, like project.getGradle().getGradleVersion() is project.gradle.gradleVersion.
|
|
|
|
// Since the buildscript is provided with a project, you can call project methods without qualification if there is no
|
|
|
|
// ambiguity, such as file() call to retrieve version is project.file(), and gradle is project.getGradle()
|
|
|
|
logger.lifecycle "Setting up ${archivesBaseName} ${version} with Gradle ${gradle.gradleVersion}"
|
|
|
|
|
|
|
|
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.
|
|
|
|
}
|
|
|
|
|
|
|
|
dependencies {
|
|
|
|
// To change the versions see the gradle.properties file
|
|
|
|
minecraft "com.mojang:minecraft:${project.minecraft_version}"
|
|
|
|
mappings "net.fabricmc:yarn:${project.yarn_mappings}:v2"
|
|
|
|
modImplementation "net.fabricmc:fabric-loader:${project.loader_version}"
|
|
|
|
|
|
|
|
// Fabric API. This is technically optional, but you probably want it anyway.
|
|
|
|
modImplementation "net.fabricmc.fabric-api:fabric-api:${project.fabric_version}"
|
|
|
|
}
|
|
|
|
|
|
|
|
tasks.withType(JavaCompile).configureEach {
|
|
|
|
// ensure that the encoding is set to UTF-8, no matter what the system default is
|
|
|
|
// this fixes some edge cases with special characters not displaying correctly
|
|
|
|
// see http://yodaconditions.net/blog/fix-for-java-file-encoding-problems-with-gradle.html
|
|
|
|
// If Javadoc is generated, this must be specified in that task too.
|
|
|
|
it.options.encoding = "UTF-8"
|
|
|
|
|
|
|
|
// Minecraft 1.17 (21w19a) upwards uses Java 16.
|
|
|
|
it.options.release = 16
|
|
|
|
}
|
|
|
|
|
|
|
|
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()
|
|
|
|
}
|
|
|
|
|
|
|
|
jar {
|
|
|
|
from("LICENSE") {
|
|
|
|
rename { "${it}_${project.archivesBaseName}"}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// configure the maven publication
|
|
|
|
publishing {
|
|
|
|
publications {
|
|
|
|
mavenJava(MavenPublication) {
|
|
|
|
// add all the jars that should be included when publishing to maven
|
|
|
|
artifact(remapJar) {
|
|
|
|
builtBy remapJar
|
|
|
|
}
|
|
|
|
artifact(sourcesJar) {
|
|
|
|
builtBy remapSourcesJar
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 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.
|
|
|
|
}
|
|
|
|
}
|