2023-01-06 06:01:46 -07:00
plugins {
2023-06-25 14:42:42 -06:00
id "com.modrinth.minotaur" version "2.+"
2023-01-06 06:01:46 -07:00
id 'maven-publish'
alias libs . plugins . quilt . loom
}
archivesBaseName = project . archives_base_name
2023-06-25 14:42:42 -06:00
version = "${project.version}"
2023-01-06 06:01:46 -07:00
group = project . maven_group
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 "org.quiltmc:quilt-mappings:${libs.versions.quilt.mappings.get()}: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 // If you wish to use Fabric API's deprecated modules, you can replace the above line with this one
}
processResources {
inputs . property 'version' , version
filesMatching ( 'quilt.mod.json' ) {
expand "version" : version
}
}
tasks . withType ( JavaCompile ) . configureEach {
it . options . encoding = 'UTF-8'
// Minecraft 1.18 (1.18-pre2) upwards uses Java 17.
it . options . release = 17
}
java {
// Still required by IDEs such as Eclipse and Visual Studio Code
sourceCompatibility = JavaVersion . VERSION_17
targetCompatibility = JavaVersion . VERSION_17
// 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()
}
// If you plan to use a different file for the license, don't forget to change the file name here!
jar {
from ( 'LICENSE' ) {
rename { "${it}_${archivesBaseName}" }
}
}
2023-06-25 14:42:42 -06:00
//modrinth
import com.modrinth.minotaur.dependencies.ModDependency
tasks . modrinth . dependsOn ( tasks . modrinthSyncBody )
modrinth {
token = System . getenv ( "MODRINTH_TOKEN" ) // Please use an environment variable for this! The default is `$MODRINTH_TOKEN`.
projectId = "roses-quilt" // The ID of your Modrinth project. Slugs will not work.
versionNumber = version // The (preferably SemVer) version of the mod. If not specified, it'll use the `version` declaration
versionType = "release" // This is the default -- can also be `beta` or `alpha`
uploadFile = remapJar // Tells Minotaur to use the remapped jar
gameVersions = [ "1.20" , "1.20.1" ] // An array of game versions the version supports
loaders = [ "quilt" ] // Self-explanatory.
changelog = "changed log! (wait about a minute, and refresh, it will be here)"
dependencies { // A special DSL for creating dependencies
// scope.type
// The scope can be `required`, `optional`, `incompatible`, or `embedded`
// The type can either be `project` or `version`
required . project "qsl" // Creates a new required dependency on Fabric API
optional . project "modmenu" //, "mc1.19.3-0.4.8" // Creates a new optional dependency on this specific version of Sodium
}
syncBodyFrom = rootProject . file ( "README.md" ) . text
}
2023-01-06 06:01:46 -07:00
// Configure the maven publication
publishing {
publications {
mavenJava ( MavenPublication ) {
from components . 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.
}
}