From 822fb70abf3f983d7adc51735fdaaaaa02d6eadf Mon Sep 17 00:00:00 2001 From: zml Date: Mon, 22 Jan 2024 20:16:08 -0800 Subject: [PATCH 01/10] chore(build): bump gradle plugins, add junit launcher to resolve some deprecations --- build.gradle.kts | 1 + settings.gradle.kts | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/build.gradle.kts b/build.gradle.kts index b317fa2594..8768a66817 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -128,6 +128,7 @@ dependencies { testImplementation("org.junit.jupiter:junit-jupiter-api") testImplementation("org.junit.jupiter:junit-jupiter-params") testRuntimeOnly("org.junit.jupiter:junit-jupiter-engine") + testRuntimeOnly("org.junit.platform:junit-platform-launcher") testImplementation("org.hamcrest:hamcrest:2.2") testImplementation("org.mockito:mockito-core:$mockitoVersion") } diff --git a/settings.gradle.kts b/settings.gradle.kts index e698cafef5..10eb03ac24 100644 --- a/settings.gradle.kts +++ b/settings.gradle.kts @@ -9,7 +9,7 @@ pluginManagement { plugins { val indraVersion = "3.1.3" id("org.spongepowered.gradle.event-impl-gen") version "7.0.0" - id("org.spongepowered.gradle.sponge.dev") version "2.1.1" + id("org.spongepowered.gradle.sponge.dev") version "2.2.0" id("org.jetbrains.gradle.plugin.idea-ext") version "1.1.7" id("net.ltgt.errorprone") version "3.1.0" id("net.kyori.indra.publishing") version indraVersion From 9bd831a8c7e9f208e2af018d9ce593d7fbb5056a Mon Sep 17 00:00:00 2001 From: zml Date: Tue, 23 Jan 2024 14:50:15 -0800 Subject: [PATCH 02/10] chore(build): Move to using version catalogs for dependencies --- build.gradle.kts | 102 ++++++++++++++++---------------------- gradle.properties | 14 ------ gradle/libs.versions.toml | 65 ++++++++++++++++++++++++ settings.gradle.kts | 12 +---- 4 files changed, 110 insertions(+), 83 deletions(-) create mode 100644 gradle/libs.versions.toml diff --git a/build.gradle.kts b/build.gradle.kts index 8768a66817..d70476244c 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -2,20 +2,20 @@ import net.ltgt.gradle.errorprone.errorprone buildscript { dependencies { - classpath("fr.inria.gforge.spoon:spoon-core:10.2.0") // bump for EIG + classpath(libs.spoon) // bump for EIG } } plugins { eclipse - id("org.spongepowered.gradle.sponge.dev") - id("net.kyori.indra.checkstyle") - id("net.kyori.indra.crossdoc") - id("net.kyori.indra.publishing") - id("net.kyori.indra.publishing.sonatype") - id("org.spongepowered.gradle.event-impl-gen") - id("org.jetbrains.gradle.plugin.idea-ext") - id("net.ltgt.errorprone") + alias(libs.plugins.spongeGradle.convention) + alias(libs.plugins.indra.checkstyle) + alias(libs.plugins.indra.crossdoc) + alias(libs.plugins.indra.publishing) + alias(libs.plugins.indra.publishing.sonatype) + alias(libs.plugins.eventImplGen) + alias(libs.plugins.ideaExt) + alias(libs.plugins.errorprone) } repositories { @@ -29,44 +29,32 @@ val ap by sourceSets.registering { } // Project dependencies -val adventureVersion: String by project -val configurateVersion: String by project -val gsonVersion: String by project -val log4jVersion: String by project -val mathVersion: String by project dependencies { - val caffeineVersion: String by project - val errorproneVersion: String by project - val junitVersion: String by project - val mockitoVersion: String by project - val pluginSpiVersion: String by project - val checkerVersion: String by project - // Directly tied to what's available from Minecraft - api("org.apache.logging.log4j:log4j-api:$log4jVersion") - api("com.google.code.gson:gson:$gsonVersion") + api(libs.log4j.api) + api(libs.gson) // Adventure - api(platform("net.kyori:adventure-bom:$adventureVersion")) - api("net.kyori:adventure-api") { + api(platform(libs.adventure.bom)) + api(libs.adventure.api) { exclude(group = "org.jetbrains", module = "annotations") } - api("net.kyori:adventure-text-serializer-gson") { + api(libs.adventure.textSerializer.gson) { exclude(group = "com.google.code.gson", module = "gson") exclude(group = "net.kyori", module = "adventure-api") } - api("net.kyori:adventure-text-serializer-legacy") { + api(libs.adventure.textSerializer.legacy) { exclude(group = "net.kyori", module = "adventure-api") } - api("net.kyori:adventure-text-serializer-plain") { + api(libs.adventure.textSerializer.plain) { exclude(group = "net.kyori", module = "adventure-api") } - api("net.kyori:adventure-text-minimessage") { + api(libs.adventure.minimessage) { exclude(group = "net.kyori", module = "adventure-api") } // Dependency injection - api("com.google.inject:guice:5.0.1") { + api(libs.guice) { exclude(group = "com.google.code.findbugs", module = "jsr305") // We don't want to use jsr305, use checkerframework exclude(group = "javax.inject", module = "javax.inject") exclude(group = "com.google.guava", module = "guava") // We use an older version than Guice does @@ -74,7 +62,7 @@ dependencies { } // High performance cache + guava - shaded guava - api("com.github.ben-manes.caffeine:caffeine:$caffeineVersion") { + api(libs.caffeine) { exclude(group = "org.checkerframework", module = "checker-qual") exclude(group = "com.google.errorprone", module = "error_prone_annotations") exclude(group = "org.junit", module = "junit-bom") @@ -84,53 +72,53 @@ dependencies { } // Plugin spi, includes plugin-meta - api("org.spongepowered:plugin-spi:$pluginSpiVersion") { + api(libs.pluginSpi) { exclude(group = "org.checkerframework", module = "checker-qual") exclude(group = "com.google.code.gson", module = "gson") exclude(group = "org.apache.logging.log4j", module = "log4j-api") } // Configurate - api(platform("org.spongepowered:configurate-bom:$configurateVersion")) - api("org.spongepowered:configurate-core") { + api(platform(libs.configurate.bom)) + api(libs.configurate.core) { exclude(group = "org.checkerframework", module = "checker-qual") // We use our own version } - api("org.spongepowered:configurate-hocon") { + api(libs.configurate.hocon) { exclude(group = "org.spongepowered", module = "configurate-core") exclude(group = "org.checkerframework", module = "checker-qual") } - api("org.spongepowered:configurate-gson") { + api(libs.configurate.gson) { exclude(group = "org.spongepowered", module = "configurate-core") exclude(group = "com.google.code.gson", module = "gson") // We have the same version technically, but use the gson we provide. exclude(group = "org.checkerframework", module = "checker-qual") } - api("org.spongepowered:configurate-yaml") { + api(libs.configurate.yaml) { exclude(group = "org.spongepowered", module = "configurate-core") exclude(group = "org.checkerframework", module = "checker-qual") } - api("org.spongepowered:configurate-extra-guice") { + api(libs.configurate.extraGuice) { exclude(group = "com.google.inject", module = "guice") } // Compile-time static analysis - compileOnly("com.google.errorprone:error_prone_annotations:$errorproneVersion") - errorprone("com.google.errorprone:error_prone_core:$errorproneVersion") + compileOnly(libs.errorprone.annotations) + errorprone(libs.errorprone) // Math library - api("org.spongepowered:math:$mathVersion") { + api(libs.math) { exclude(group = "com.google.errorprone", module = "error_prone_annotations") } - compileOnlyApi("org.checkerframework:checker-qual:$checkerVersion") + compileOnlyApi(libs.checkerQual) - testImplementation(platform("org.junit:junit-bom:$junitVersion")) - testImplementation("org.junit.jupiter:junit-jupiter-api") - testImplementation("org.junit.jupiter:junit-jupiter-params") - testRuntimeOnly("org.junit.jupiter:junit-jupiter-engine") - testRuntimeOnly("org.junit.platform:junit-platform-launcher") - testImplementation("org.hamcrest:hamcrest:2.2") - testImplementation("org.mockito:mockito-core:$mockitoVersion") + testImplementation(platform(libs.junit.bom)) + testImplementation(libs.junit.api) + testImplementation(libs.junit.params) + testRuntimeOnly(libs.junit.engine) + testRuntimeOnly(libs.junit.launcher) + testImplementation(libs.hamcrest) + testImplementation(libs.mockito) } tasks { @@ -181,14 +169,14 @@ tasks { options { (this as? StandardJavadocDocletOptions)?.apply { links( - "https://logging.apache.org/log4j/log4j-$log4jVersion/log4j-api/apidocs/", - "https://google.github.io/guice/api-docs/5.0.1/javadoc/", - "https://configurate.aoeu.xyz/$configurateVersion/apidocs/", - "https://www.javadoc.io/doc/com.google.code.gson/gson/$gsonVersion/", - "https://jd.spongepowered.org/math/$mathVersion" + "https://logging.apache.org/log4j/log4j-${libs.versions.log4j.get()}/log4j-api/apidocs/", + "https://google.github.io/guice/api-docs/${libs.versions.guice.get()}/javadoc/", + "https://configurate.aoeu.xyz/${libs.versions.configurate.get()}/apidocs/", + "https://www.javadoc.io/doc/com.google.code.gson/gson/${libs.versions.gson.get()}/", + "https://jd.spongepowered.org/math/${libs.versions.math.get()}" ) sequenceOf("api", "key", "text-serializer-gson", "text-serializer-legacy", "text-serializer-plain").forEach { - links("https://jd.advntr.dev/$it/$adventureVersion/") + links("https://jd.advntr.dev/$it/${libs.versions.adventure.get()}/") } addBooleanOption("quiet", true) } @@ -250,12 +238,10 @@ spongeConvention { } indra { - val checkstyleVersion: String by project - javaVersions { target(17) } - checkstyle(checkstyleVersion) + checkstyle(libs.versions.checkstyle.get()) configurePublications { artifactId = project.name.lowercase() diff --git a/gradle.properties b/gradle.properties index 19f319e283..c74132f2ff 100644 --- a/gradle.properties +++ b/gradle.properties @@ -7,17 +7,3 @@ projectDescription=A plugin API for Minecraft: Java Edition javadocPublishRoot=https://jd.spongepowered.org/ org.gradle.parallel=true - -adventureVersion=4.12.0 -caffeineVersion=3.1.8 -checkstyleVersion=10.12.4 -configurateVersion=4.1.2 -errorproneVersion=2.23.0 -gsonVersion=2.10.1 -junitVersion=5.9.1 -log4jVersion=2.19.0 - -mathVersion=2.0.1 -mockitoVersion=4.8.0 -pluginSpiVersion=0.3.0 -checkerVersion=3.26.0 diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml new file mode 100644 index 0000000000..75f9b27cc6 --- /dev/null +++ b/gradle/libs.versions.toml @@ -0,0 +1,65 @@ +[metadata] +format = { version = "1.1" } + +[versions] +adventure = "4.12.0" +caffeine = "3.1.8" +checker = "3.26.0" +checkstyle = "10.12.4" +configurate = "4.1.2" +errorprone = "2.23.0" +gson = "2.10.1" +guice = "5.0.1" +indra = "3.1.3" +junit = "5.9.1" +log4j = "2.19.0" +math = "2.0.1" +mockito = "4.8.0" +pluginSpi = "0.3.0" + +[libraries] +adventure-bom = { module = "net.kyori:adventure-bom", version.ref = "adventure" } +adventure-api = { module = "net.kyori:adventure-api" } +adventure-textSerializer-gson = { module = "net.kyori:adventure-text-serializer-gson" } +adventure-textSerializer-legacy = { module = "net.kyori:adventure-text-serializer-legacy" } +adventure-textSerializer-plain = { module = "net.kyori:adventure-text-serializer-plain" } +adventure-minimessage = { module = "net.kyori:adventure-text-minimessage" } +caffeine = { module = "com.github.ben-manes.caffeine:caffeine", version.ref = "caffeine" } +configurate-bom = { module = "org.spongepowered:configurate-bom", version.ref = "configurate" } +configurate-core = { module = "org.spongepowered:configurate-core" } +configurate-hocon = { module = "org.spongepowered:configurate-hocon" } +configurate-gson = { module = "org.spongepowered:configurate-gson" } +configurate-yaml = { module = "org.spongepowered:configurate-yaml" } +configurate-extraGuice = { module = "org.spongepowered:configurate-extra-guice" } +gson = { module = "com.google.code.gson:gson", version.ref = "gson" } +guice = { module = "com.google.inject:guice", version.ref = "guice" } +log4j-api = { module = "org.apache.logging.log4j:log4j-api", version.ref = "log4j" } +math = { module = "org.spongepowered:math", version.ref = "math" } +pluginSpi = { module = "org.spongepowered:plugin-spi", version.ref = "pluginSpi" } + +# build-time/annotations + +checkerQual = { module = "org.checkerframework:checker-qual", version.ref = "checker" } +errorprone = { module = "com.google.errorprone:error_prone_core", version.ref = "errorprone" } +errorprone-annotations = { module = "com.google.errorprone:error_prone_annotations", version.ref = "errorprone" } +spoon = { module = "fr.inria.gforge.spoon:spoon-core", version = "10.2.0" } # bump for EIG + +# testing + +hamcrest = { module = "org.hamcrest:hamcrest", version = "2.2" } +junit-bom = { module = "org.junit:junit-bom", version.ref = "junit" } +junit-api = { module = "org.junit.jupiter:junit-jupiter-api" } +junit-params = { module = "org.junit.jupiter:junit-jupiter-params" } +junit-engine = { module = "org.junit.jupiter:junit-jupiter-engine" } +junit-launcher = { module = "org.junit.platform:junit-platform-launcher" } +mockito = { module = "org.mockito:mockito-core", version.ref = "mockito" } + +[plugins] +errorprone = { id = "net.ltgt.errorprone", version = "3.1.0" } +eventImplGen = { id = "org.spongepowered.gradle.event-impl-gen", version = "7.0.0" } +ideaExt = { id = "org.jetbrains.gradle.plugin.idea-ext", version = "1.1.7" } +indra-checkstyle = { id = "net.kyori.indra.checkstyle", version.ref = "indra" } +indra-crossdoc = { id = "net.kyori.indra.crossdoc", version.ref = "indra" } +indra-publishing = { id = "net.kyori.indra.publishing", version.ref = "indra" } +indra-publishing-sonatype = { id = "net.kyori.indra.publishing.sonatype", version.ref = "indra" } +spongeGradle-convention = { id = "org.spongepowered.gradle.sponge.dev", version = "2.2.0" } diff --git a/settings.gradle.kts b/settings.gradle.kts index 10eb03ac24..f88ee9ef65 100644 --- a/settings.gradle.kts +++ b/settings.gradle.kts @@ -6,18 +6,8 @@ pluginManagement { name = "sponge" } } - plugins { - val indraVersion = "3.1.3" - id("org.spongepowered.gradle.event-impl-gen") version "7.0.0" - id("org.spongepowered.gradle.sponge.dev") version "2.2.0" - id("org.jetbrains.gradle.plugin.idea-ext") version "1.1.7" - id("net.ltgt.errorprone") version "3.1.0" - id("net.kyori.indra.publishing") version indraVersion - id("net.kyori.indra.publishing.sonatype") version indraVersion - id("net.kyori.indra.checkstyle") version indraVersion - id("net.kyori.indra.crossdoc") version indraVersion - } } + plugins { id("org.gradle.toolchains.foojay-resolver-convention") version ("0.7.0") } From ebdf422a0386fcb452807e58ec161eed698b6a6e Mon Sep 17 00:00:00 2001 From: zml Date: Tue, 23 Jan 2024 14:52:17 -0800 Subject: [PATCH 03/10] chore(build): remove duplicated repository declaration --- build.gradle.kts | 6 ------ settings.gradle.kts | 5 +++++ 2 files changed, 5 insertions(+), 6 deletions(-) diff --git a/build.gradle.kts b/build.gradle.kts index d70476244c..03c6341691 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -18,12 +18,6 @@ plugins { alias(libs.plugins.errorprone) } -repositories { - maven("https://repo.spongepowered.org/repository/maven-public/") { - name = "sponge" - } -} - val ap by sourceSets.registering { compileClasspath += sourceSets.main.get().compileClasspath + sourceSets.main.get().output } diff --git a/settings.gradle.kts b/settings.gradle.kts index f88ee9ef65..cab2525a93 100644 --- a/settings.gradle.kts +++ b/settings.gradle.kts @@ -11,3 +11,8 @@ pluginManagement { plugins { id("org.gradle.toolchains.foojay-resolver-convention") version ("0.7.0") } + +dependencyResolutionManagement { + repositoriesMode = RepositoriesMode.FAIL_ON_PROJECT_REPOS + pluginManagement.repositories.forEach(repositories::add) +} From 031a972269c5d9a3182aed1b32b86b6772d2b639 Mon Sep 17 00:00:00 2001 From: zml Date: Tue, 23 Jan 2024 14:56:56 -0800 Subject: [PATCH 04/10] chore(build): Clean up idea-ext blocks --- build.gradle.kts | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/build.gradle.kts b/build.gradle.kts index 03c6341691..91c00324ae 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -1,4 +1,7 @@ import net.ltgt.gradle.errorprone.errorprone +import org.jetbrains.gradle.ext.delegateActions +import org.jetbrains.gradle.ext.settings +import org.jetbrains.gradle.ext.taskTriggers buildscript { dependencies { @@ -195,14 +198,12 @@ tasks { idea { if (project != null) { - (project as ExtensionAware).extensions["settings"].run { - require(this is ExtensionAware) - - this.extensions.getByType(org.jetbrains.gradle.ext.ActionDelegationConfig::class).run { + project.settings.run { + delegateActions { delegateBuildRunToGradle = false testRunner = org.jetbrains.gradle.ext.ActionDelegationConfig.TestRunner.PLATFORM } - this.extensions.getByType(org.jetbrains.gradle.ext.TaskTriggersConfig::class).run { + taskTriggers { beforeBuild(tasks.genEventImpl) } } From fa78292e4972e5368f16c87e59dafd362479b3cb Mon Sep 17 00:00:00 2001 From: zml Date: Tue, 23 Jan 2024 15:03:59 -0800 Subject: [PATCH 05/10] chore(deps): Bump misc dependencies --- gradle/libs.versions.toml | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 75f9b27cc6..784206fb77 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -4,17 +4,17 @@ format = { version = "1.1" } [versions] adventure = "4.12.0" caffeine = "3.1.8" -checker = "3.26.0" -checkstyle = "10.12.4" +checker = "3.42.0" +checkstyle = "10.12.7" configurate = "4.1.2" -errorprone = "2.23.0" +errorprone = "2.24.1" gson = "2.10.1" guice = "5.0.1" indra = "3.1.3" -junit = "5.9.1" +junit = "5.10.1" log4j = "2.19.0" math = "2.0.1" -mockito = "4.8.0" +mockito = "5.9.0" pluginSpi = "0.3.0" [libraries] @@ -42,7 +42,7 @@ pluginSpi = { module = "org.spongepowered:plugin-spi", version.ref = "pluginSpi" checkerQual = { module = "org.checkerframework:checker-qual", version.ref = "checker" } errorprone = { module = "com.google.errorprone:error_prone_core", version.ref = "errorprone" } errorprone-annotations = { module = "com.google.errorprone:error_prone_annotations", version.ref = "errorprone" } -spoon = { module = "fr.inria.gforge.spoon:spoon-core", version = "10.2.0" } # bump for EIG +spoon = { module = "fr.inria.gforge.spoon:spoon-core", version = "10.4.2" } # bump for EIG # testing From 08930b96a472b314f8d9394e1f6e7d4b82624afa Mon Sep 17 00:00:00 2001 From: zml Date: Tue, 23 Jan 2024 15:08:39 -0800 Subject: [PATCH 06/10] chore(build): Silence some warnings from Adventure references --- build.gradle.kts | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/build.gradle.kts b/build.gradle.kts index 91c00324ae..a919b0cea5 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -25,6 +25,14 @@ val ap by sourceSets.registering { compileClasspath += sourceSets.main.get().compileClasspath + sourceSets.main.get().output } +configurations { + sequenceOf(apiElements, runtimeElements).forEach { + it.configure { + exclude(group = "org.jetbrains", module = "annotations") + } + } +} + // Project dependencies dependencies { // Directly tied to what's available from Minecraft @@ -33,9 +41,7 @@ dependencies { // Adventure api(platform(libs.adventure.bom)) - api(libs.adventure.api) { - exclude(group = "org.jetbrains", module = "annotations") - } + api(libs.adventure.api) api(libs.adventure.textSerializer.gson) { exclude(group = "com.google.code.gson", module = "gson") exclude(group = "net.kyori", module = "adventure-api") @@ -120,7 +126,7 @@ dependencies { tasks { genEventImpl { - sourceCompatibility = "16" + sourceCompatibility = "17" destinationDir = project.layout.buildDirectory.dir("generated/event-factory").get().asFile outputFactory = "org.spongepowered.api.event.SpongeEventFactory" From 559840062e611b713f5e37bc6066748220d67980 Mon Sep 17 00:00:00 2001 From: zml Date: Tue, 23 Jan 2024 16:51:56 -0800 Subject: [PATCH 07/10] chore(build): Resolve remaining deprecation warnings --- build.gradle.kts | 3 ++- gradle/libs.versions.toml | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/build.gradle.kts b/build.gradle.kts index a919b0cea5..dcc499983c 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -19,6 +19,7 @@ plugins { alias(libs.plugins.eventImplGen) alias(libs.plugins.ideaExt) alias(libs.plugins.errorprone) + alias(libs.plugins.nexusPublish) } val ap by sourceSets.registering { @@ -127,7 +128,7 @@ dependencies { tasks { genEventImpl { sourceCompatibility = "17" - destinationDir = project.layout.buildDirectory.dir("generated/event-factory").get().asFile + destinationDirectory = project.layout.buildDirectory.dir("generated/event-factory") outputFactory = "org.spongepowered.api.event.SpongeEventFactory" include("org/spongepowered/api/event/*/**/*") diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 784206fb77..707ee08772 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -56,10 +56,11 @@ mockito = { module = "org.mockito:mockito-core", version.ref = "mockito" } [plugins] errorprone = { id = "net.ltgt.errorprone", version = "3.1.0" } -eventImplGen = { id = "org.spongepowered.gradle.event-impl-gen", version = "7.0.0" } +eventImplGen = { id = "org.spongepowered.gradle.event-impl-gen", version = "7.1.0" } ideaExt = { id = "org.jetbrains.gradle.plugin.idea-ext", version = "1.1.7" } indra-checkstyle = { id = "net.kyori.indra.checkstyle", version.ref = "indra" } indra-crossdoc = { id = "net.kyori.indra.crossdoc", version.ref = "indra" } indra-publishing = { id = "net.kyori.indra.publishing", version.ref = "indra" } indra-publishing-sonatype = { id = "net.kyori.indra.publishing.sonatype", version.ref = "indra" } +nexusPublish = { id = "io.github.gradle-nexus.publish-plugin", version = "2.0.0-rc-1"} spongeGradle-convention = { id = "org.spongepowered.gradle.sponge.dev", version = "2.2.0" } From 78d22fb9206ceb247457cb9e4fcddf8df00c3fd0 Mon Sep 17 00:00:00 2001 From: zml Date: Tue, 23 Jan 2024 17:09:28 -0800 Subject: [PATCH 08/10] chore(build): break out idea-ext version for impl use --- gradle/libs.versions.toml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 707ee08772..3c4d734882 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -10,6 +10,7 @@ configurate = "4.1.2" errorprone = "2.24.1" gson = "2.10.1" guice = "5.0.1" +ideaExt = "1.1.7" indra = "3.1.3" junit = "5.10.1" log4j = "2.19.0" @@ -57,7 +58,7 @@ mockito = { module = "org.mockito:mockito-core", version.ref = "mockito" } [plugins] errorprone = { id = "net.ltgt.errorprone", version = "3.1.0" } eventImplGen = { id = "org.spongepowered.gradle.event-impl-gen", version = "7.1.0" } -ideaExt = { id = "org.jetbrains.gradle.plugin.idea-ext", version = "1.1.7" } +ideaExt = { id = "org.jetbrains.gradle.plugin.idea-ext", version.ref = "ideaExt" } indra-checkstyle = { id = "net.kyori.indra.checkstyle", version.ref = "indra" } indra-crossdoc = { id = "net.kyori.indra.crossdoc", version.ref = "indra" } indra-publishing = { id = "net.kyori.indra.publishing", version.ref = "indra" } From 7808c911b0c40029d64ec88bd948f18433e45211 Mon Sep 17 00:00:00 2001 From: zml Date: Tue, 23 Jan 2024 18:56:22 -0800 Subject: [PATCH 09/10] chore(build): Bump foojay plugin version --- settings.gradle.kts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/settings.gradle.kts b/settings.gradle.kts index cab2525a93..9007387b61 100644 --- a/settings.gradle.kts +++ b/settings.gradle.kts @@ -9,7 +9,7 @@ pluginManagement { } plugins { - id("org.gradle.toolchains.foojay-resolver-convention") version ("0.7.0") + id("org.gradle.toolchains.foojay-resolver-convention") version ("0.8.0") } dependencyResolutionManagement { From ed34adb06ebdda706d0a2407c18631cc3f9915a5 Mon Sep 17 00:00:00 2001 From: zml Date: Tue, 23 Jan 2024 19:03:06 -0800 Subject: [PATCH 10/10] chore(build): Declare our Java target in one central place --- build.gradle.kts | 5 +++-- gradle.properties | 1 + 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/build.gradle.kts b/build.gradle.kts index dcc499983c..6eb9da096e 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -22,6 +22,7 @@ plugins { alias(libs.plugins.nexusPublish) } +val javaTarget: String by project val ap by sourceSets.registering { compileClasspath += sourceSets.main.get().compileClasspath + sourceSets.main.get().output } @@ -127,7 +128,7 @@ dependencies { tasks { genEventImpl { - sourceCompatibility = "17" + sourceCompatibility = javaTarget destinationDirectory = project.layout.buildDirectory.dir("generated/event-factory") outputFactory = "org.spongepowered.api.event.SpongeEventFactory" @@ -241,7 +242,7 @@ spongeConvention { indra { javaVersions { - target(17) + target(javaTarget.toInt()) } checkstyle(libs.versions.checkstyle.get()) diff --git a/gradle.properties b/gradle.properties index c74132f2ff..969e73ca4f 100644 --- a/gradle.properties +++ b/gradle.properties @@ -3,6 +3,7 @@ version=11.0.0-SNAPSHOT organization=SpongePowered projectUrl=https://www.spongepowered.org projectDescription=A plugin API for Minecraft: Java Edition +javaTarget=17 javadocPublishRoot=https://jd.spongepowered.org/