generated from FabricMC/fabric-example-mod
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.gradle
145 lines (124 loc) · 3.85 KB
/
build.gradle
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
plugins {
id 'fabric-loom' version '1.9-SNAPSHOT'
id 'maven-publish'
id "me.modmuss50.mod-publish-plugin" version "0.6.3"
}
version = project.mod_version + "+" + project.minecraft_version
group = project.maven_group
base {
archivesName = project.archives_base_name
}
sourceSets {
main {
resources {
srcDirs += [
'src/main/generated'
]
}
}
}
loom {
accessWidenerPath = file("src/main/resources/combat-plus.accesswidener")
runs {
// This adds a new gradle task that runs the datagen API: "gradlew runDatagen"
datagen {
inherit client
name "Data Generation"
vmArg "-Dfabric-api.datagen"
vmArg "-Dfabric-api.datagen.output-dir=${file("src/main/generated")}"
vmArg "-Dfabric-api.datagen.modid=${modid}"
runDir "build/datagen"
}
}
}
repositories {
mavenLocal()
maven { url "https://jitpack.io" }
}
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}"
modApi "com.github.Provismet:lilylib:${project.lilylib_version}"
include "com.github.Provismet:lilylib:${project.lilylib_version}"
}
processResources {
inputs.property "version", project.version
filesMatching("fabric.mod.json") {
expand "version": project.version
}
}
tasks.withType(JavaCompile).configureEach {
it.options.release = 21
}
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()
sourceCompatibility = JavaVersion.VERSION_21
targetCompatibility = JavaVersion.VERSION_21
}
jar {
from("LICENSE") {
rename { "${it}_${project.base.archivesName.get()}"}
}
}
publishMods {
file = remapJar.archiveFile
additionalFiles.from(remapSourcesJar.archiveFile)
changelog = file("changelog.md").text
type = STABLE
modLoaders.add("fabric")
modLoaders.add("quilt")
displayName = project.version.toString()
dryRun = providers.environmentVariable("GITHUB_TOKEN").getOrNull() == null || providers.environmentVariable("MODRINTH_TOKEN").getOrNull() == null || providers.environmentVariable("CURSEFORGE_TOKEN").getOrNull() == null
github {
repository = "Provismet/${project.github_repo}"
accessToken = providers.environmentVariable("GITHUB_TOKEN")
commitish = "${project.github_branch}"
tagName = "${project.mod_version}-mc${project.minecraft_version}"
allowEmptyFiles = true
displayName = "${project.mod_version} - ${project.minecraft_version}"
}
modrinth {
projectId = project.modrinth_id
accessToken = providers.environmentVariable("MODRINTH_TOKEN")
minecraftVersionRange {
start = project.version_start
end = project.version_end
}
requires("fabric-api")
}
curseforge {
projectId = project.curseforge_id
accessToken = providers.environmentVariable("CURSEFORGE_TOKEN")
clientRequired = true
serverRequired = true
minecraftVersionRange {
start = project.version_start
end = project.version_end
}
requires("fabric-api")
}
}
// configure the maven publication
publishing {
publications {
mavenJava(MavenPublication) {
version = project.mod_version + "-mc" + project.minecraft_version
artifactId = project.archives_base_name
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.
}
}