forked from VulpixelMC/quilt-kotlin-template-mod
-
Notifications
You must be signed in to change notification settings - Fork 0
/
build.gradle.kts
197 lines (158 loc) · 5.73 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
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
@file:Suppress("UnstableApiUsage")
import nl.javadude.gradle.plugins.license.License
import org.jetbrains.kotlin.gradle.dsl.JvmTarget
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
@Suppress("DSL_SCOPE_VIOLATION")
plugins {
id("com.github.hierynomus.license").version("0.16.1")
id("org.jetbrains.kotlin.jvm").version("1.8.10")
id("org.quiltmc.quilt-mappings-on-loom") version "4.2.1"
alias(libs.plugins.quilt.loom)
`maven-publish`
}
val modVersion: String by project
val mavenGroup: String by project
val modId: String by project
val modName: String by project
base.archivesBaseName = modId
version = modVersion
group = 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 {
name = "TerraformersMC"
url = uri("https://maven.terraformersmc.com/")
}
maven {
name = "Modrinth"
url = uri("https://api.modrinth.com/maven")
content {
includeGroup("maven.modrinth")
}
}
maven {
url = uri("https://maven.bai.lol")
}
maven {
name = "Cursed Maven"
url = uri("https://cursemaven.com")
content {
includeGroup("curse.maven")
}
}
maven {
url = uri("https://repo.minelittlepony-mod.com/maven/release")
}
maven {
name = "Gegy"
url = uri("https://maven.gegy.dev")
}
maven {
url = uri("https://nexus.velocitypowered.com/repository/maven-public/")
}
maven {
name = "QuiltMC Snapshot"
url = uri("https://maven.quiltmc.org/repository/snapshot")
}
maven {
url = uri("https://maven.ryanliptak.com/")
}
}
val modImplementationInclude by configurations.register("modImplementationInclude")
configurations {
modImplementationInclude
modImplementationInclude.setExtendsFrom(mutableListOf(configurations.modImplementation.get(), configurations.include.get()))
}
// 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(loom.layered {
mappings("org.quiltmc:quilt-mappings:${libs.versions.minecraft.get()}+build.${libs.versions.quilt.mappings.get()}:intermediary-v2")
})
modImplementation(libs.quilt.loader)
modImplementation(libs.quilt.lang.kotlin) {
exclude(group = "org.quiltmc.qsl.item")
exclude(group = "org.quiltmc.qsl.entity")
}
// 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
modImplementation(libs.core.qsl.base)
modImplementation(libs.core.networking)
modImplementation(libs.core.registry)
modImplementation(libs.block.entity)
modImplementation(libs.block.extensions)
modImplementation(libs.item.setting)
// cursed library collection
// implementation(include("net.auoeke", "reflect", "5.+"))
// implementation(include("net.gudenau.lib", "unsafe", "latest.release"))
// implementation(include("org.objenesis", "objenesis", "3.3"))
// more cursed libraries
// implementation("net.bytebuddy", "byte-buddy-agent", "1.12.+")
// modImplementation("maven.modrinth", "yqh", "0.1.2")
// must-have libraries
modCompileOnly(libs.wthit.api)
modCompileOnly(libs.emi.api)
// runtime mods
modLocalRuntime(libs.emi.api)
// add(sourceSets.main.get().getTaskName("mod", JavaPlugin.IMPLEMENTATION_CONFIGURATION_NAME), modImplementationInclude)
// add(net.fabricmc.loom.util.Constants.Configurations.INCLUDE, modImplementationInclude)
}
tasks.processResources {
inputs.property("version", version)
filesMatching("quilt.mod.json") {
expand("group" to mavenGroup, "id" to modId, "version" to version, "name" to modName)
}
filesMatching("**/lang/*.json") {
expand("id" to modId)
}
}
tasks.withType<JavaCompile> {
options.encoding = "UTF-8"
// Minecraft 1.18 (1.18-pre2) upwards uses Java 17.
options.release.set(17)
}
tasks.withType<KotlinCompile> {
// Minecraft 1.18 (1.18-pre2) upwards uses Java 17.
compilerOptions.jvmTarget.set(JvmTarget.JVM_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 developement.
// 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.withType<AbstractArchiveTask> {
from("COPYING", "COPYING.LESSER").rename { "${it}_${modId}" }
from("*.aseprite", "*.ase", "*.pal").exclude()
}
tasks.build {
dependsOn(tasks.license)
}
tasks.withType<License> {
header = file("LHEADER")
exclude("**/*.json")
}
// Configure the maven publication
publishing {
publications {}
// 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.
}
}