From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Kyle Wood Date: Thu, 10 Dec 2020 20:50:33 -0800 Subject: [PATCH] Convert project to Gradle The pom.xml file is deleted in this patch so the patch will fail to apply if there are changes made to it from upstream - thus notifying us that changes were made. diff --git a/.gitignore b/.gitignore index 11038da2e071699d6561a331565db0c8d7850d0e..317acfec5894101294a55abff61819431e6a5e65 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,5 @@ +.gradle/ + # Eclipse stuff /.classpath /.project @@ -31,3 +33,7 @@ *.ipr *.iws .idea/ + +# vs code +/.vscode +/.factorypath diff --git a/build.gradle.kts b/build.gradle.kts new file mode 100644 index 0000000000000000000000000000000000000000..c2e5d8006420aab5a60e5aaa188223aeb0396483 --- /dev/null +++ b/build.gradle.kts @@ -0,0 +1,86 @@ +plugins { + `java-library` + `maven-publish` +} + +java { + withSourcesJar() + withJavadocJar() +} + +val annotationsVersion = "24.0.1" +val bungeeCordChatVersion = "1.20-R0.1" + +dependencies { + // api dependencies are listed transitively to API consumers + api("com.google.guava:guava:31.1-jre") + api("com.google.code.gson:gson:2.10") + api("net.md-5:bungeecord-chat:$bungeeCordChatVersion") + api("org.yaml:snakeyaml:2.0") + api("org.joml:joml:1.10.5") + + compileOnly("org.apache.maven:maven-resolver-provider:3.8.5") + compileOnly("org.apache.maven.resolver:maven-resolver-connector-basic:1.7.3") + compileOnly("org.apache.maven.resolver:maven-resolver-transport-http:1.7.3") + + val annotations = "org.jetbrains:annotations-java5:$annotationsVersion" + compileOnly(annotations) + testCompileOnly(annotations) + + testImplementation("org.apache.commons:commons-lang3:3.12.0") + testImplementation("junit:junit:4.13.2") + testImplementation("org.hamcrest:hamcrest-library:1.3") + testImplementation("org.ow2.asm:asm-tree:9.5") +} + +configure { + publications.create("maven") { + from(components["java"]) + } +} + +val generateApiVersioningFile by tasks.registering { + inputs.property("version", project.version) + val pomProps = layout.buildDirectory.file("pom.properties") + outputs.file(pomProps) + val projectVersion = project.version + doLast { + pomProps.get().asFile.writeText("version=$projectVersion") + } +} + +tasks.jar { + from(generateApiVersioningFile.map { it.outputs.files.singleFile }) { + into("META-INF/maven/${project.group}/${project.name}") + } + manifest { + attributes( + "Automatic-Module-Name" to "org.bukkit" + ) + } +} + +tasks.withType { + val options = options as StandardJavadocDocletOptions + options.overview = "src/main/javadoc/overview.html" + options.use() + options.isDocFilesSubDirs = true + options.links( + "https://guava.dev/releases/31.1-jre/api/docs/", + "https://javadoc.io/doc/org.yaml/snakeyaml/2.0/", + "https://javadoc.io/doc/org.jetbrains/annotations-java5/$annotationsVersion/", + "https://javadoc.io/doc/net.md-5/bungeecord-chat/$bungeeCordChatVersion/", + ) + options.tags("apiNote:a:API Note:") + + // workaround for https://github.com/gradle/gradle/issues/4046 + inputs.dir("src/main/javadoc").withPropertyName("javadoc-sourceset") + doLast { + copy { + from("src/main/javadoc") { + include("**/doc-files/**") + } + into("build/docs/javadoc") + } + } +} diff --git a/pom.xml b/pom.xml deleted file mode 100644 index 068987ca1171857fc9996d645e775448a09f0feb..0000000000000000000000000000000000000000 --- a/pom.xml +++ /dev/null @@ -1,270 +0,0 @@ - - - 4.0.0 - - org.spigotmc - spigot-api - 1.20.1-R0.1-SNAPSHOT - jar - - Spigot-API - https://www.spigotmc.org/ - An enhanced plugin API for Minecraft servers. - - - true - 1.8 - 1.8 - UTF-8 - - - - - spigotmc-releases - https://hub.spigotmc.org/nexus/content/repositories/releases/ - - - spigotmc-snapshots - https://hub.spigotmc.org/nexus/content/repositories/snapshots/ - - - - - - - com.google.guava - guava - 31.1-jre - compile - - - - com.google.code.gson - gson - 2.10 - compile - - - - org.joml - joml - 1.10.5 - compile - - - net.md-5 - bungeecord-chat - 1.20-R0.1 - jar - compile - - - org.yaml - snakeyaml - 2.0 - compile - - - - org.apache.maven - maven-resolver-provider - 3.8.5 - provided - - - org.apache.maven.resolver - maven-resolver-connector-basic - 1.7.3 - provided - - - org.apache.maven.resolver - maven-resolver-transport-http - 1.7.3 - provided - - - - org.jetbrains - annotations-java5 - 24.0.1 - provided - - - - junit - junit - 4.13.2 - test - - - org.hamcrest - hamcrest-library - 1.3 - test - - - org.ow2.asm - asm-tree - 9.5 - test - - - - - - - net.md-5 - scriptus - 0.5.0 - - - initialize - - describe - - - - - - org.apache.maven.plugins - maven-compiler-plugin - 3.11.0 - - - eclipse - - false - - - - org.codehaus.plexus - plexus-compiler-eclipse - 2.13.0 - - - - - org.apache.maven.plugins - maven-jar-plugin - 3.3.0 - - - - false - - - org.bukkit - - - - - - org.apache.maven.plugins - maven-shade-plugin - 3.5.0 - - - package - - shade - - - - - - - *:* - - META-INF/MANIFEST.MF - - - - - true - - false - - - - org.apache.maven.plugins - maven-javadoc-plugin - 3.5.0 - - - https://guava.dev/releases/31.1-jre/api/docs/ - https://javadoc.io/doc/org.yaml/snakeyaml/2.0/ - https://javadoc.io/doc/org.jetbrains/annotations-java5/24.0.1/ - https://javadoc.io/doc/net.md-5/bungeecord-chat/1.20-R0.1/ - - - - apiNote - a - API Note: - - - - - - - - - - development - - false - - - - - org.apache.maven.plugins - maven-checkstyle-plugin - 3.3.0 - - - process-classes - - check - - - - - checkstyle.xml - checkstyle-suppressions.xml - true - - - - com.puppycrawl.tools - checkstyle - 8.45.1 - - - - - org.codehaus.mojo - animal-sniffer-maven-plugin - 1.23 - - - process-classes - - check - - - - - - org.codehaus.mojo.signature - java18 - 1.0 - - - - - - - -