-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbuild.gradle
More file actions
129 lines (106 loc) · 4.05 KB
/
build.gradle
File metadata and controls
129 lines (106 loc) · 4.05 KB
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
plugins {
id 'fml-loom' version '0.1'
id 'maven-publish'
}
version = project.mod_version
group = project.maven_group
base {
// The name of the generated JAR file.
// "[xxxx]" + project.archives_base_name to add an alias
archivesName = project.archives_base_name
}
//base {
// archivesName = "[中文名]" + project.archives_base_name
//}
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 = "Spongepowered"
url = "https://repo.spongepowered.org/repository/maven-public/"
}// Dependency library(FastUtil, Gson, etc) download source
maven {
name = "ModdedMITE"
url = "https://maven.limingzxc.top/repository/maven-public/"
}// Mods & Loaders download source
}
configurations {
fml
}
dependencies {
// To change the versions see the gradle.properties file
minecraft "com.mojang:minecraft:${project.minecraft_version}"
modImplementation "net.fabricmc:fabric-loader:${project.loader_version}"
implementation("it.unimi.dsi:fastutil:8.5.12")
implementation("com.google.code.gson:gson:2.11.0")
fml "com.github.MinecraftIsTooEasy:FishModLoader:3.4.2"
implementation "com.github.MinecraftIsTooEasy:FishModLoader:3.4.2"
// The most basic dependency library mod, with a status similar to Fabric API
implementation "com.github.MinecraftIsTooEasy:RustedIronCore:1.5.0"
// To add strong dependencies, use "implementation" like above
// To compile mod integrations(e.g. ModMenu), use "compileOnly"
// To add mods for running client, use "localRuntime"
}
def fmlResolvedFile = configurations.fml.files.iterator().next()
loom {
accessWidenerPath = file("src/main/resources/modid.accesswidener")
mergedMinecraftJar()
mods {
"modid" {
sourceSet sourceSets.main
// sourceSet sourceSets.client
// sourceSet sourceSets.server
// For modules in the ’src‘ directory, only the main module is required by default
}
}
}
loom.setFML(fmlResolvedFile)
dependencies.add("mappings", loom.fmlMCPMappings())
processResources {
inputs.property "version", project.version
filesMatching("fml.mod.json") {
expand "version": project.version
}
}
tasks.withType(JavaCompile).configureEach {
it.options.release = 17
}
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_17
targetCompatibility = JavaVersion.VERSION_17
}
jar {
inputs.property "archivesName", project.base.archivesName
from("LICENSE") {
rename { "${it}_${inputs.properties.archivesName}"}
}
}
tasks.named('runClient', JavaExec).configure { exec ->
def user = project.hasProperty('username') ? project.username : 'Dev'
def width = project.hasProperty('screen_width') ? project.screen_width : '854'
def height = project.hasProperty('screen_height') ? project.screen_height : '480'
exec.setArgs(['--username', user, '--session', '0', '--width', width, '--height', height])
}
// configure the maven publication
publishing {
publications {
mavenJava(MavenPublication) {
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.
}
}