2022-02-27 22:38:55 +00:00
|
|
|
import net.kyori.blossom.BlossomExtension
|
|
|
|
|
|
|
|
plugins {
|
|
|
|
id("net.kyori.blossom")
|
2022-02-28 04:43:06 +00:00
|
|
|
id("net.kyori.indra.git")
|
2022-04-24 18:35:49 +00:00
|
|
|
id("geyser.publish-conventions")
|
2022-02-27 22:38:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
dependencies {
|
|
|
|
api(projects.common)
|
2023-02-09 16:34:27 +00:00
|
|
|
api(projects.api)
|
2022-02-27 22:38:55 +00:00
|
|
|
|
|
|
|
// Jackson JSON and YAML serialization
|
2022-09-26 15:43:17 +00:00
|
|
|
api(libs.bundles.jackson)
|
|
|
|
api(libs.guava)
|
2022-02-27 22:38:55 +00:00
|
|
|
|
|
|
|
// Fastutil Maps
|
2022-09-26 15:43:17 +00:00
|
|
|
implementation(libs.bundles.fastutil)
|
2022-02-27 22:38:55 +00:00
|
|
|
|
|
|
|
// Network libraries
|
2022-09-26 15:43:17 +00:00
|
|
|
implementation(libs.websocket)
|
2022-02-27 22:38:55 +00:00
|
|
|
|
2022-10-30 00:23:21 +00:00
|
|
|
api(libs.bundles.protocol)
|
2022-02-27 22:38:55 +00:00
|
|
|
|
2022-09-26 15:43:17 +00:00
|
|
|
api(libs.mcauthlib)
|
|
|
|
api(libs.mcprotocollib) {
|
2022-09-20 18:25:39 +00:00
|
|
|
exclude("io.netty", "netty-all")
|
2022-03-20 01:46:30 +00:00
|
|
|
exclude("com.github.GeyserMC", "packetlib")
|
|
|
|
exclude("com.github.GeyserMC", "mcauthlib")
|
2022-02-27 22:38:55 +00:00
|
|
|
}
|
|
|
|
|
2022-09-26 15:43:17 +00:00
|
|
|
implementation(libs.raknet) {
|
2023-06-17 01:39:53 +00:00
|
|
|
exclude("io.netty", "*")
|
2022-02-27 22:38:55 +00:00
|
|
|
}
|
|
|
|
|
2022-09-26 15:43:17 +00:00
|
|
|
implementation(libs.netty.resolver.dns)
|
|
|
|
implementation(libs.netty.resolver.dns.native.macos) { artifact { classifier = "osx-x86_64" } }
|
|
|
|
implementation(libs.netty.codec.haproxy)
|
2022-02-27 22:38:55 +00:00
|
|
|
|
|
|
|
// Network dependencies we are updating ourselves
|
2022-09-26 15:43:17 +00:00
|
|
|
api(libs.netty.handler)
|
2022-02-27 22:38:55 +00:00
|
|
|
|
2022-09-26 15:43:17 +00:00
|
|
|
implementation(libs.netty.transport.native.epoll) { artifact { classifier = "linux-x86_64" } }
|
|
|
|
implementation(libs.netty.transport.native.epoll) { artifact { classifier = "linux-aarch_64" } }
|
|
|
|
implementation(libs.netty.transport.native.kqueue) { artifact { classifier = "osx-x86_64" } }
|
2022-02-27 22:38:55 +00:00
|
|
|
|
|
|
|
// Adventure text serialization
|
2022-10-24 17:26:28 +00:00
|
|
|
api(libs.bundles.adventure)
|
2022-02-27 22:38:55 +00:00
|
|
|
|
2023-03-30 19:44:55 +00:00
|
|
|
api(libs.erosion.common) {
|
|
|
|
isTransitive = false
|
|
|
|
}
|
|
|
|
|
2022-02-27 22:38:55 +00:00
|
|
|
// Test
|
2022-09-26 15:43:17 +00:00
|
|
|
testImplementation(libs.junit)
|
2022-02-27 22:38:55 +00:00
|
|
|
|
|
|
|
// Annotation Processors
|
2022-03-20 02:13:37 +00:00
|
|
|
compileOnly(projects.ap)
|
2022-02-27 23:26:50 +00:00
|
|
|
|
2022-02-27 22:38:55 +00:00
|
|
|
annotationProcessor(projects.ap)
|
2023-04-22 18:53:46 +00:00
|
|
|
|
|
|
|
api(libs.events)
|
2022-02-27 22:38:55 +00:00
|
|
|
}
|
|
|
|
|
2022-09-18 19:11:18 +00:00
|
|
|
configurations.api {
|
|
|
|
// This is still experimental - additionally, it could only really benefit standalone
|
|
|
|
exclude(group = "io.netty.incubator", module = "netty-incubator-transport-native-io_uring")
|
|
|
|
}
|
|
|
|
|
2022-09-19 15:22:09 +00:00
|
|
|
tasks.processResources {
|
|
|
|
// This is solely for backwards compatibility for other programs that used this file before the switch to gradle.
|
|
|
|
// It used to be generated by the maven Git-Commit-Id-Plugin
|
|
|
|
filesMatching("git.properties") {
|
|
|
|
val info = GitInfo()
|
|
|
|
expand(
|
|
|
|
"branch" to info.branch,
|
|
|
|
"buildNumber" to info.buildNumber,
|
|
|
|
"projectVersion" to project.version,
|
|
|
|
"commit" to info.commit,
|
|
|
|
"commitAbbrev" to info.commitAbbrev,
|
|
|
|
"commitMessage" to info.commitMessage,
|
|
|
|
"repository" to info.repository
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
2022-02-28 04:43:06 +00:00
|
|
|
|
2022-09-19 15:22:09 +00:00
|
|
|
configure<BlossomExtension> {
|
2022-02-27 22:38:55 +00:00
|
|
|
val mainFile = "src/main/java/org/geysermc/geyser/GeyserImpl.java"
|
2022-09-19 15:22:09 +00:00
|
|
|
val info = GitInfo()
|
|
|
|
|
|
|
|
replaceToken("\${version}", "${project.version} (${info.gitVersion})", mainFile)
|
|
|
|
replaceToken("\${gitVersion}", info.gitVersion, mainFile)
|
|
|
|
replaceToken("\${buildNumber}", info.buildNumber, mainFile)
|
|
|
|
replaceToken("\${branch}", info.branch, mainFile)
|
|
|
|
replaceToken("\${commit}", info.commit, mainFile)
|
|
|
|
replaceToken("\${repository}", info.repository, mainFile)
|
2022-02-28 05:01:24 +00:00
|
|
|
}
|
|
|
|
|
2022-02-28 05:11:27 +00:00
|
|
|
fun Project.buildNumber(): Int =
|
2023-05-27 13:05:41 +00:00
|
|
|
(System.getenv("GITHUB_RUN_NUMBER") ?: jenkinsBuildNumber())?.let { Integer.parseInt(it) } ?: -1
|
2022-09-19 15:22:09 +00:00
|
|
|
|
|
|
|
inner class GitInfo {
|
|
|
|
val branch: String
|
|
|
|
val commit: String
|
|
|
|
val commitAbbrev: String
|
|
|
|
|
|
|
|
val gitVersion: String
|
|
|
|
val version: String
|
|
|
|
val buildNumber: Int
|
|
|
|
|
|
|
|
val commitMessage: String
|
|
|
|
val repository: String
|
|
|
|
|
|
|
|
init {
|
|
|
|
// On Jenkins, a detached head is checked out, so indra cannot determine the branch.
|
|
|
|
// Fortunately, this environment variable is available.
|
|
|
|
branch = indraGit.branchName() ?: System.getenv("BRANCH_NAME") ?: "DEV"
|
|
|
|
|
|
|
|
val commit = indraGit.commit()
|
|
|
|
this.commit = commit?.name ?: "0".repeat(40)
|
|
|
|
commitAbbrev = commit?.name?.substring(0, 7) ?: "0".repeat(7)
|
|
|
|
|
|
|
|
gitVersion = "git-${branch}-${commitAbbrev}"
|
|
|
|
version = "${project.version} ($gitVersion)"
|
|
|
|
buildNumber = buildNumber()
|
|
|
|
|
|
|
|
val git = indraGit.git()
|
|
|
|
commitMessage = git?.commit()?.message ?: ""
|
|
|
|
repository = git?.repository?.config?.getString("remote", "origin", "url") ?: ""
|
|
|
|
}
|
|
|
|
}
|
2023-05-27 13:05:41 +00:00
|
|
|
|
|
|
|
// todo remove this when we're not using Jenkins anymore
|
2023-05-27 13:12:20 +00:00
|
|
|
fun jenkinsBuildNumber(): String? = System.getenv("BUILD_NUMBER")
|