-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.gradle.kts
130 lines (105 loc) · 4.4 KB
/
build.gradle.kts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
plugins {
id("maven-publish")
alias(libs.plugins.quilt.loom)
alias(libs.plugins.mod.publish.plugin)
}
class ModData {
val version = property("version").toString()
val mavenGroup = property("maven_group").toString()
val id = property("id").toString()
}
val mod = ModData()
base {
archivesName = mod.id
}
version = "${mod.version}+${libs.versions.minecraft.get()}"
group = mod.mavenGroup
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.
maven("https://api.modrinth.com/maven") { name = "Modrinth" }
maven("https://maven.nucleoid.xyz/") { name = "Nucleoid" }
}
loom {
// Loom and Loader both use this block in order to gather more information about your mod.
mods {
// This should match your mod id.
create(mod.id) {
// Tell Loom about each source set used by your mod here. This ensures that your mod's classes are properly transformed by Loader.
sourceSet("main")
// If you shade (directly include classes, not JiJ) a dependency into your mod, include it here using one of these methods:
// dependency("com.example.shadowedmod:1.2.3")
// configuration("exampleShadedConfigurationName")
}
}
}
// 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") })
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.bundles.quilted.fabric.api)
// modImplementation(libs.bundles.quilted.fabric.api.deprecated) // If you wish to use Fabric API's deprecated modules, you can replace the above line with this one
modImplementation(libs.placeholder.api)
include(libs.placeholder.api)
modImplementation(libs.polymer.core)
include(libs.polymer.core)
modRuntimeOnly(libs.mod.menu)
}
tasks.processResources {
val map = mapOf("version" to version, "id" to mod.id, "group" to project.group)
inputs.properties(map)
filesMatching("quilt.mod.json") {
expand(map)
}
}
java {
// Still required by IDEs such as Eclipse and Visual Studio Code
sourceCompatibility = JavaVersion.VERSION_21
targetCompatibility = JavaVersion.VERSION_21
// 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!
tasks.jar {
from(project.file("LICENSE"))
}
publishMods {
displayName = "styled renaming ${mod.version}"
file = tasks.remapJar.get().archiveFile
changelog = project.file("CHANGELOG.md").readText()
type = STABLE
modLoaders.add("quilt")
dryRun = !providers.environmentVariable("MODRINTH_TOKEN").isPresent()
modrinth {
projectId = "Z87eUIv0"
accessToken = providers.environmentVariable("MODRINTH_TOKEN")
minecraftVersions.add(libs.versions.minecraft)
requires("qsl")
}
}
// Configure the maven publication
publishing {
publications {
create<MavenPublication>("mavenJava") {
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.
}
}