From 430bbd9aa71921adaf7634475ce277c42c14a902 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 09:48:28 +0200 Subject: [PATCH 001/204] Created example module --- example/build.gradle | 22 ++++++++++++++++++++++ gradle/libs.versions.toml | 2 ++ settings.gradle | 4 +++- 3 files changed, 27 insertions(+), 1 deletion(-) create mode 100644 example/build.gradle diff --git a/example/build.gradle b/example/build.gradle new file mode 100644 index 00000000..28b580ec --- /dev/null +++ b/example/build.gradle @@ -0,0 +1,22 @@ +plugins { + id 'groovy' + id 'application' + id 'com.github.johnrengelman.shadow' version '8.1.1' +} + +dependencies { + implementation libs.groovy +} + +shadowJar { + exclude("META-INF/**") + archiveFileName = "${project.name}-${project.version}.jar" + mainClassName = "${project.group}.yagl.YAGL" +} + +jar { + enabled = true // Required for sub projects depending on sub projects + duplicatesStrategy = DuplicatesStrategy.EXCLUDE + archiveFileName = "${project.name}-${project.version}-original.jar" + dependsOn(shadowJar) +} \ No newline at end of file diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 58990277..89d8bc27 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -1,5 +1,6 @@ [versions] delombok = "8.4" +groovy = "4.0.16" fulmicollection = "1.5.2" yamlparser = "1.6.2" @@ -17,6 +18,7 @@ mockito = "4.11.0" jbukkit = "2.1" [libraries] +groovy = { module = "org.apache.groovy:groovy", version.ref = "groovy" } fulmicollection = { module = "it.fulminazzo:FulmiCollection", version.ref = "fulmicollection" } yamlparser = { module = "it.fulminazzo:YAMLParser", version.ref = "yamlparser" } diff --git a/settings.gradle b/settings.gradle index c26efb45..32268302 100644 --- a/settings.gradle +++ b/settings.gradle @@ -52,4 +52,6 @@ gradleEnterprise { termsOfServiceAgree = 'yes' } } -} \ No newline at end of file +} +include 'example' + From 71fccbf9959ff34ab9882bdd7380000a244194c8 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 09:53:29 +0200 Subject: [PATCH 002/204] Added spigot dependency --- example/build.gradle | 2 ++ 1 file changed, 2 insertions(+) diff --git a/example/build.gradle b/example/build.gradle index 28b580ec..da33f2e1 100644 --- a/example/build.gradle +++ b/example/build.gradle @@ -6,6 +6,8 @@ plugins { dependencies { implementation libs.groovy + + compileOnly libs.spigot.latest } shadowJar { From a40d794f74a535ea9db1b4a5ecdd4b93b6625266 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 09:57:43 +0200 Subject: [PATCH 003/204] Added processResources task and reworked other tasks --- example/build.gradle | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/example/build.gradle b/example/build.gradle index da33f2e1..36f0a5f4 100644 --- a/example/build.gradle +++ b/example/build.gradle @@ -11,14 +11,26 @@ dependencies { } shadowJar { - exclude("META-INF/**") - archiveFileName = "${project.name}-${project.version}.jar" - mainClassName = "${project.group}.yagl.YAGL" + exclude 'META-INF/**' + + archiveFileName = "${rootProject.name}-${project.version}.jar" + mainClassName = "${project.group}.${rootProject.name.toLowerCase()}.${rootProject.name}" } jar { - enabled = true // Required for sub projects depending on sub projects - duplicatesStrategy = DuplicatesStrategy.EXCLUDE + dependsOn processResources + dependsOn shadowJar + archiveFileName = "${project.name}-${project.version}-original.jar" - dependsOn(shadowJar) +} + +processResources { + def props = [ + version: rootProject.version, name: rootProject.name, name_lower: rootProject.name.toLowerCase(), + description: rootProject.description, author: 'Fulminazzo', + group: rootProject.group, module: rootProject.name + ] + inputs.properties props + filteringCharset 'UTF-8' + expand props } \ No newline at end of file From e753f62000c40a9587b7aaf875f544da41fdea65 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 10:01:37 +0200 Subject: [PATCH 004/204] Created plugin.yml --- example/src/main/resources/plugin.yml | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 example/src/main/resources/plugin.yml diff --git a/example/src/main/resources/plugin.yml b/example/src/main/resources/plugin.yml new file mode 100644 index 00000000..4b3349e3 --- /dev/null +++ b/example/src/main/resources/plugin.yml @@ -0,0 +1,6 @@ +name: "${name}" +description: "${description}" +version: "${version}" +authors: ["${author}"] +main: "${group}.${name_lower}.${name}" +api-version: 1.13 From 3b9af6f25a4cc2b8622b4804eb77b6e29a8292a7 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 10:01:44 +0200 Subject: [PATCH 005/204] Created basic YAGL main class --- .../src/main/groovy/it/angrybear/yagl/YAGL.groovy | 15 +++++++++++++++ 1 file changed, 15 insertions(+) create mode 100644 example/src/main/groovy/it/angrybear/yagl/YAGL.groovy diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy new file mode 100644 index 00000000..990c314a --- /dev/null +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -0,0 +1,15 @@ +package it.angrybear.yagl + +import groovy.transform.CompileDynamic +import org.bukkit.plugin.java.JavaPlugin + +@CompileDynamic +class YAGL extends JavaPlugin { + + @Override + void onEnable() { + def str = "Hello world" + getLogger().info(str) + } + +} From 5315218aee0695179a4fbd627de1012f96ee6c4a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 10:04:25 +0200 Subject: [PATCH 006/204] Fixed main project including example in final build --- build.gradle | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/build.gradle b/build.gradle index 82ca2f5f..3b4db612 100644 --- a/build.gradle +++ b/build.gradle @@ -9,6 +9,7 @@ group = 'it.angrybear' version = '4.0' final def TEST_MODULE = "testing" +final def EXAMPLE_MODULE = "example" final def VERSION_VARIABLE = "MINECRAFT_VERSION" allprojects { @@ -111,9 +112,6 @@ allprojects { api(project(":common:common-${id}")) } - if (!projectName.contains("-")) - subprojects.findAll { (it.name != TEST_MODULE) } .each {api project(it.path)} - testCompileOnly libs.lombok testAnnotationProcessor libs.lombok @@ -184,6 +182,10 @@ allprojects { } } +dependencies { + subprojects.findAll { it.name != TEST_MODULE && it.name != EXAMPLE_MODULE } .each { api project(it.path) } +} + testCodeCoverageReport { dependsOn test reports { From 6e40fe046fa3017d5a781ad6d44b2ffad4eb9c65 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 10:06:57 +0200 Subject: [PATCH 007/204] Added dependency to main project --- example/build.gradle | 1 + 1 file changed, 1 insertion(+) diff --git a/example/build.gradle b/example/build.gradle index 36f0a5f4..8a047104 100644 --- a/example/build.gradle +++ b/example/build.gradle @@ -6,6 +6,7 @@ plugins { dependencies { implementation libs.groovy + implementation project(":") compileOnly libs.spigot.latest } From e24501110b5f594f4ce2de5c110ff15655593687 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 11:27:51 +0200 Subject: [PATCH 008/204] Renamed final archive to YAGL-plugin --- example/build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/example/build.gradle b/example/build.gradle index 8a047104..a987f2c3 100644 --- a/example/build.gradle +++ b/example/build.gradle @@ -14,7 +14,7 @@ dependencies { shadowJar { exclude 'META-INF/**' - archiveFileName = "${rootProject.name}-${project.version}.jar" + archiveFileName = "${rootProject.name}-plugin-${project.version}.jar" mainClassName = "${project.group}.${rootProject.name.toLowerCase()}.${rootProject.name}" } From e5bdfd4b145c51751db785d167305cf7f399d4fe Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:07:16 +0200 Subject: [PATCH 009/204] Added spigot dependency for tests --- example/build.gradle | 1 + 1 file changed, 1 insertion(+) diff --git a/example/build.gradle b/example/build.gradle index a987f2c3..bd066fb1 100644 --- a/example/build.gradle +++ b/example/build.gradle @@ -9,6 +9,7 @@ dependencies { implementation project(":") compileOnly libs.spigot.latest + testImplementation libs.spigot.latest } shadowJar { From fffd6fad502cec2e960073de35fdccc9f073b840 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:07:32 +0200 Subject: [PATCH 010/204] Created ShellCommand with execute implementation --- .../yagl/commands/ShellCommand.groovy | 35 +++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy diff --git a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy new file mode 100644 index 00000000..a4183ec9 --- /dev/null +++ b/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy @@ -0,0 +1,35 @@ +package it.angrybear.yagl.commands + +import groovy.transform.CompileStatic +import it.angrybear.yagl.YAGL +import it.fulminazzo.fulmicollection.utils.ClassUtils +import it.fulminazzo.yamlparser.utils.FileUtils +import org.bukkit.command.Command +import org.bukkit.command.CommandSender +import org.jetbrains.annotations.NotNull + +@CompileStatic +class ShellCommand extends Command { + private final String shellCode + + ShellCommand(final @NotNull File file) { + super(file.getName().substring(0, file.getName().lastIndexOf('.'))) + def imports = ClassUtils.findClassesInPackage(YAGL.package.name) + .collect({ "import ${it.package.name}.*" }) + .reverse().unique().join("\n") + def code = FileUtils.readFileToString(file) + this.shellCode = "${imports}\n${code}\nrun(sender, label, args)" + } + + @Override + boolean execute(@NotNull CommandSender sender, @NotNull String label, @NotNull String[] args) { + Binding binding = new Binding(["sender": sender, "label": label, "args": args]) + new GroovyShell(binding).evaluate(this.shellCode) + return true + } + + @Override + List tabComplete(@NotNull CommandSender sender, @NotNull String alias, @NotNull String[] args) throws IllegalArgumentException { + return new ArrayList<>() + } +} From 6b6f5031f5aee009e9f3d41c466439c332404a9a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:07:47 +0200 Subject: [PATCH 011/204] Added test suite for ShellCommand execution --- .../yagl/commands/ShellCommandTest.java | 32 +++++++++++++++++++ .../src/test/resources/shell-command.groovy | 3 ++ 2 files changed, 35 insertions(+) create mode 100644 example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java create mode 100644 example/src/test/resources/shell-command.groovy diff --git a/example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java b/example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java new file mode 100644 index 00000000..7be883b5 --- /dev/null +++ b/example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java @@ -0,0 +1,32 @@ +package it.angrybear.yagl.commands; + +import org.bukkit.command.CommandSender; +import org.junit.jupiter.api.Test; + +import java.io.File; +import java.util.concurrent.atomic.AtomicReference; + +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.mockito.Mockito.*; + +class ShellCommandTest { + + @Test + void testExecute() { + // Prepare file + File file = new File("build/resources/test/shell-command.groovy"); + // Prepare sender + AtomicReference message = new AtomicReference<>(); + CommandSender sender = mock(CommandSender.class); + doAnswer(a -> { + message.set(a.getArgument(0)); + return null; + }).when(sender).sendMessage(anyString()); + + ShellCommand shellCommand = new ShellCommand(file); + shellCommand.execute(sender, "command", new String[0]); + + assertEquals("Hello world", message.get()); + } + +} \ No newline at end of file diff --git a/example/src/test/resources/shell-command.groovy b/example/src/test/resources/shell-command.groovy new file mode 100644 index 00000000..aa6ca73a --- /dev/null +++ b/example/src/test/resources/shell-command.groovy @@ -0,0 +1,3 @@ +def run = { sender, label, args -> + sender.sendMessage("Hello world") +} \ No newline at end of file From f0071c39cac0177cf869ad02cb05711cb3d60546 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:08:42 +0200 Subject: [PATCH 012/204] Added Javadoc --- .../groovy/it/angrybear/yagl/commands/ShellCommand.groovy | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy index a4183ec9..774e0236 100644 --- a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy @@ -8,10 +8,18 @@ import org.bukkit.command.Command import org.bukkit.command.CommandSender import org.jetbrains.annotations.NotNull +/** + * A general class used to create a command from a Groovy script. + */ @CompileStatic class ShellCommand extends Command { private final String shellCode + /** + * Instantiates a new shell command + * + * @param file the file containing the script + */ ShellCommand(final @NotNull File file) { super(file.getName().substring(0, file.getName().lastIndexOf('.'))) def imports = ClassUtils.findClassesInPackage(YAGL.package.name) From 179da95d64819c13c89060eabb75f3eff484ee57 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:28:25 +0200 Subject: [PATCH 013/204] Added saveDefaultCommands method --- .../main/groovy/it/angrybear/yagl/YAGL.groovy | 25 +++++++++++++++++-- 1 file changed, 23 insertions(+), 2 deletions(-) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 990c314a..cff829c0 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -1,15 +1,36 @@ package it.angrybear.yagl import groovy.transform.CompileDynamic +import it.angrybear.yagl.commands.ShellCommand +import it.fulminazzo.yamlparser.utils.FileUtils import org.bukkit.plugin.java.JavaPlugin +import org.jetbrains.annotations.NotNull @CompileDynamic class YAGL extends JavaPlugin { + final List commands = new ArrayList<>() @Override void onEnable() { - def str = "Hello world" - getLogger().info(str) + + } + + /** + * Saves all the default command scripts to the given directory + * + * @param commandsDir the output directory + */ + void saveDefaultCommands(final @NotNull File commandsDir) { + final def containingFolder = '/commands' + FileUtils.createFolder(commandsDir) + getClass().getResourceAsStream(containingFolder).withReader { + def fileName = it.readLine() + def file = new File(commandsDir, fileName) + FileUtils.createNewFile(file) + def input = getClass().getResourceAsStream("${containingFolder}/${fileName}") + def output = new FileOutputStream(file) + output << input + } } } From 66f7d6963da67a83b1a35fcd6d35bd2a763bf854 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:29:33 +0200 Subject: [PATCH 014/204] Created mock command for testing purposes --- example/src/test/resources/commands/mock.groovy | 1 + 1 file changed, 1 insertion(+) create mode 100644 example/src/test/resources/commands/mock.groovy diff --git a/example/src/test/resources/commands/mock.groovy b/example/src/test/resources/commands/mock.groovy new file mode 100644 index 00000000..f9cab74f --- /dev/null +++ b/example/src/test/resources/commands/mock.groovy @@ -0,0 +1 @@ +def str = 'content' \ No newline at end of file From 4618807e814b980bcf22277a6e52f698b3bd19d0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:32:26 +0200 Subject: [PATCH 015/204] Added test suite for saveDefaultCommands --- .../test/java/it/angrybear/yagl/YAGLTest.java | 38 +++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 example/src/test/java/it/angrybear/yagl/YAGLTest.java diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/example/src/test/java/it/angrybear/yagl/YAGLTest.java new file mode 100644 index 00000000..2117d001 --- /dev/null +++ b/example/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -0,0 +1,38 @@ +package it.angrybear.yagl; + +import it.fulminazzo.yamlparser.utils.FileUtils; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; + +import java.io.File; +import java.io.IOException; + +import static org.junit.jupiter.api.Assertions.*; +import static org.mockito.Mockito.*; + +class YAGLTest { + private YAGL plugin; + + @BeforeEach + void setUp() throws IOException { + this.plugin = mock(YAGL.class); + File dataDir = new File("build/resources/test/plugin"); + if (dataDir.exists()) FileUtils.deleteFolder(dataDir); + when(this.plugin.getDataFolder()).thenReturn(dataDir); + doCallRealMethod().when(this.plugin).saveDefaultCommands(any()); + } + + @Test + void testSaveDefaultCommands() throws IOException { + final String fileName = "commands/mock.groovy"; + File expected = new File(this.plugin.getDataFolder(), fileName); + String expectedContent = FileUtils.readFileToString(new File("build/resources/test/" + fileName)); + + this.plugin.saveDefaultCommands(expected.getParentFile()); + + assertTrue(expected.exists(), String.format("Expected file '%s' to exist", expected.getAbsolutePath())); + String actualContent = FileUtils.readFileToString(expected); + + assertEquals(expectedContent, actualContent, "Content did not match expected"); + } +} \ No newline at end of file From 649018f65484ce85feae177b3e5ba5c9e5480194 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:36:02 +0200 Subject: [PATCH 016/204] Added loadCommands method --- .../src/main/groovy/it/angrybear/yagl/YAGL.groovy | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index cff829c0..d42de688 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -15,6 +15,19 @@ class YAGL extends JavaPlugin { } + /** + * Loads all the commands from the {@link #getDataFolder()}/commands directory. + * If it does not exist, it is created using {@link #saveDefaultCommands(File)}. + */ + void loadCommands() { + this.commands.clear() + File commandsDir = new File(getDataFolder(), "commands") + if (!commandsDir.exists()) saveDefaultCommands(commandsDir) + File[] files = commandsDir.listFiles() + if (files != null) + this.commands.addAll(files.collect { new ShellCommand(it) }) + } + /** * Saves all the default command scripts to the given directory * From 89e40d62223bff1ad007661dfdc9a74eaa5a4c6b Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:37:33 +0200 Subject: [PATCH 017/204] Added tests for load commands method --- .../main/groovy/it/angrybear/yagl/YAGL.groovy | 2 +- .../test/java/it/angrybear/yagl/YAGLTest.java | 16 ++++++++++++++++ 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index d42de688..38d7014b 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -8,7 +8,7 @@ import org.jetbrains.annotations.NotNull @CompileDynamic class YAGL extends JavaPlugin { - final List commands = new ArrayList<>() + private final List commands = new ArrayList<>() @Override void onEnable() { diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/example/src/test/java/it/angrybear/yagl/YAGLTest.java index 2117d001..1b6f055d 100644 --- a/example/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/example/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -1,11 +1,15 @@ package it.angrybear.yagl; +import it.angrybear.yagl.commands.ShellCommand; +import it.fulminazzo.fulmicollection.objects.Refl; import it.fulminazzo.yamlparser.utils.FileUtils; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import java.io.File; import java.io.IOException; +import java.util.LinkedList; +import java.util.List; import static org.junit.jupiter.api.Assertions.*; import static org.mockito.Mockito.*; @@ -19,9 +23,21 @@ void setUp() throws IOException { File dataDir = new File("build/resources/test/plugin"); if (dataDir.exists()) FileUtils.deleteFolder(dataDir); when(this.plugin.getDataFolder()).thenReturn(dataDir); + new Refl<>(this.plugin).setFieldObject("commands", new LinkedList<>()); + doCallRealMethod().when(this.plugin).loadCommands(); doCallRealMethod().when(this.plugin).saveDefaultCommands(any()); } + @Test + void testLoadCommands() { + this.plugin.loadCommands(); + List commands = new Refl<>(this.plugin).getFieldObject("commands"); + assertNotNull(commands); + assertEquals(1, commands.size(), "Expected one command"); + ShellCommand command = commands.get(0); + assertEquals("mock", command.getName()); + } + @Test void testSaveDefaultCommands() throws IOException { final String fileName = "commands/mock.groovy"; From 966c601ed20602a93ba8dcab4d31a331e944cb38 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:40:14 +0200 Subject: [PATCH 018/204] Added tests for directory already present --- example/src/test/java/it/angrybear/yagl/YAGLTest.java | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/example/src/test/java/it/angrybear/yagl/YAGLTest.java index 1b6f055d..c1145d59 100644 --- a/example/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/example/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -38,6 +38,15 @@ void testLoadCommands() { assertEquals("mock", command.getName()); } + @Test + void testLoadCommandsFromAlreadyPresentDirectory() throws IOException { + FileUtils.createFolder(new File(this.plugin.getDataFolder(), "commands")); + this.plugin.loadCommands(); + List commands = new Refl<>(this.plugin).getFieldObject("commands"); + assertNotNull(commands); + assertEquals(0, commands.size(), "Expected zero commands"); + } + @Test void testSaveDefaultCommands() throws IOException { final String fileName = "commands/mock.groovy"; From 6b9d5cb810fcf5beb9de365b0c388f6709e5c7e5 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:40:57 +0200 Subject: [PATCH 019/204] Added loading of commands in onEnable --- example/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 38d7014b..ea58b4ee 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -12,7 +12,8 @@ class YAGL extends JavaPlugin { @Override void onEnable() { - + loadCommands() + getLogger().info("Loaded ${commands.size()} commands") } /** From 80e08eee22a6cce98fed32f5c9314a774f1485c0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:49:22 +0200 Subject: [PATCH 020/204] Added unloadCommands method and bukkit logic for loadCommands --- .../main/groovy/it/angrybear/yagl/YAGL.groovy | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index ea58b4ee..b800bc99 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -2,7 +2,11 @@ package it.angrybear.yagl import groovy.transform.CompileDynamic import it.angrybear.yagl.commands.ShellCommand +import it.fulminazzo.fulmicollection.objects.Refl import it.fulminazzo.yamlparser.utils.FileUtils +import org.bukkit.Bukkit +import org.bukkit.command.Command +import org.bukkit.command.CommandMap import org.bukkit.plugin.java.JavaPlugin import org.jetbrains.annotations.NotNull @@ -27,6 +31,31 @@ class YAGL extends JavaPlugin { File[] files = commandsDir.listFiles() if (files != null) this.commands.addAll(files.collect { new ShellCommand(it) }) + + commandMap().ifPresent { map -> this.commands.each { map.register(getName(), it) } } + } + + /** + * Unloads all the commands loaded in {@link #commands}. + */ + void unloadCommands() { + commandMap().ifPresent { map -> + Map commands = new Refl<>(map).getFieldObject("knownCommands") + if (commands == null) getLogger().warning("Could not find 'knownCommands' field in CommandMap") + else commands.keySet().clone().each { key -> + Command value = commands.get(key) + if (this.commands.contains(value)) commands.remove(key, value) + } + } + } + + private static Optional commandMap() { + def pluginManager = Bukkit.getPluginManager() + if (pluginManager == null) Optional.empty() + else { + def refl = new Refl<>(pluginManager) + Optional.ofNullable(refl.getFieldObject("commandMap")) + } } /** From 84db5a3e26a4ef190083ed998bff1553e2022e94 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:50:47 +0200 Subject: [PATCH 021/204] Added dependency to jbukkit --- example/build.gradle | 1 + 1 file changed, 1 insertion(+) diff --git a/example/build.gradle b/example/build.gradle index bd066fb1..92ee7bff 100644 --- a/example/build.gradle +++ b/example/build.gradle @@ -10,6 +10,7 @@ dependencies { compileOnly libs.spigot.latest testImplementation libs.spigot.latest + testImplementation libs.jbukkit } shadowJar { From c8293ad4e9692f5b8d9f684bf0efefb4fa8633bf Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:50:57 +0200 Subject: [PATCH 022/204] Fixed tests with BukkitUtils#setupServer call --- example/src/test/java/it/angrybear/yagl/YAGLTest.java | 2 ++ 1 file changed, 2 insertions(+) diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/example/src/test/java/it/angrybear/yagl/YAGLTest.java index c1145d59..08cd205f 100644 --- a/example/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/example/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -2,6 +2,7 @@ import it.angrybear.yagl.commands.ShellCommand; import it.fulminazzo.fulmicollection.objects.Refl; +import it.fulminazzo.jbukkit.BukkitUtils; import it.fulminazzo.yamlparser.utils.FileUtils; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; @@ -19,6 +20,7 @@ class YAGLTest { @BeforeEach void setUp() throws IOException { + BukkitUtils.setupServer(); this.plugin = mock(YAGL.class); File dataDir = new File("build/resources/test/plugin"); if (dataDir.exists()) FileUtils.deleteFolder(dataDir); From 4a63c13c3961755171598da7fe0406804e69a0aa Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:52:19 +0200 Subject: [PATCH 023/204] Added setupPluginManager method --- example/src/test/java/it/angrybear/yagl/YAGLTest.java | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/example/src/test/java/it/angrybear/yagl/YAGLTest.java index 08cd205f..afb0352b 100644 --- a/example/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/example/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -4,6 +4,10 @@ import it.fulminazzo.fulmicollection.objects.Refl; import it.fulminazzo.jbukkit.BukkitUtils; import it.fulminazzo.yamlparser.utils.FileUtils; +import org.bukkit.Bukkit; +import org.bukkit.Server; +import org.bukkit.command.SimpleCommandMap; +import org.bukkit.plugin.SimplePluginManager; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; @@ -62,4 +66,11 @@ void testSaveDefaultCommands() throws IOException { assertEquals(expectedContent, actualContent, "Content did not match expected"); } + + private void setupPluginManager() { + Server server = Bukkit.getServer(); + SimpleCommandMap commandMap = new SimpleCommandMap(server); + SimplePluginManager pluginManager = new SimplePluginManager(server, commandMap); + when(server.getPluginManager()).thenReturn(pluginManager); + } } \ No newline at end of file From 679e93bc70deb4e19bc2f645888f944178f15162 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:54:44 +0200 Subject: [PATCH 024/204] Added logic for getName method --- example/src/test/java/it/angrybear/yagl/YAGLTest.java | 1 + 1 file changed, 1 insertion(+) diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/example/src/test/java/it/angrybear/yagl/YAGLTest.java index afb0352b..a2491ffc 100644 --- a/example/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/example/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -30,6 +30,7 @@ void setUp() throws IOException { if (dataDir.exists()) FileUtils.deleteFolder(dataDir); when(this.plugin.getDataFolder()).thenReturn(dataDir); new Refl<>(this.plugin).setFieldObject("commands", new LinkedList<>()); + when(this.plugin.getName()).thenReturn("YAGL-Plugin"); doCallRealMethod().when(this.plugin).loadCommands(); doCallRealMethod().when(this.plugin).saveDefaultCommands(any()); } From d8cfca333710119e486714aa12d7a67e9bd2834f Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:56:12 +0200 Subject: [PATCH 025/204] Added tests for load and register commands with bukkit system --- example/src/test/java/it/angrybear/yagl/YAGLTest.java | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/example/src/test/java/it/angrybear/yagl/YAGLTest.java index a2491ffc..cc55553d 100644 --- a/example/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/example/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -6,6 +6,7 @@ import it.fulminazzo.yamlparser.utils.FileUtils; import org.bukkit.Bukkit; import org.bukkit.Server; +import org.bukkit.command.CommandMap; import org.bukkit.command.SimpleCommandMap; import org.bukkit.plugin.SimplePluginManager; import org.junit.jupiter.api.BeforeEach; @@ -68,6 +69,16 @@ void testSaveDefaultCommands() throws IOException { assertEquals(expectedContent, actualContent, "Content did not match expected"); } + @Test + void testLoadAndRegisterCommands() { + setupPluginManager(); + CommandMap commandMap = new Refl<>(Bukkit.getPluginManager()).getFieldObject("commandMap"); + assertNotNull(commandMap); + assertNull(commandMap.getCommand("mock"), "Not expected 'mock' command but some was found"); + this.plugin.loadCommands(); + assertNotNull(commandMap.getCommand("mock"), "Expected 'mock' command but none was found"); + } + private void setupPluginManager() { Server server = Bukkit.getServer(); SimpleCommandMap commandMap = new SimpleCommandMap(server); From 0d75b246602fbce3f63e84af9a5b7fc2e7f41d53 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sat, 13 Apr 2024 23:59:33 +0200 Subject: [PATCH 026/204] Added tests for unload and unregister commands with bukkit system --- .../test/java/it/angrybear/yagl/YAGLTest.java | 22 +++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/example/src/test/java/it/angrybear/yagl/YAGLTest.java index cc55553d..7a3bb27d 100644 --- a/example/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/example/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -6,6 +6,7 @@ import it.fulminazzo.yamlparser.utils.FileUtils; import org.bukkit.Bukkit; import org.bukkit.Server; +import org.bukkit.command.Command; import org.bukkit.command.CommandMap; import org.bukkit.command.SimpleCommandMap; import org.bukkit.plugin.SimplePluginManager; @@ -16,6 +17,7 @@ import java.io.IOException; import java.util.LinkedList; import java.util.List; +import java.util.Map; import static org.junit.jupiter.api.Assertions.*; import static org.mockito.Mockito.*; @@ -79,6 +81,26 @@ void testLoadAndRegisterCommands() { assertNotNull(commandMap.getCommand("mock"), "Expected 'mock' command but none was found"); } + @Test + void testUnloadAndUnregisterCommands() { + setupPluginManager(); + CommandMap commandMap = new Refl<>(Bukkit.getPluginManager()).getFieldObject("commandMap"); + assertNotNull(commandMap); + + ShellCommand shellCommand = new ShellCommand(new File(this.plugin.getDataFolder(), "commands/mock.groovy")); + Map knownCommands = new Refl<>(commandMap).getFieldObject("knownCommands"); + assertNotNull(knownCommands); + knownCommands.put("mock", shellCommand); + + List commands = new Refl<>(this.plugin).getFieldObject("commands"); + assertNotNull(commands); + commands.add(shellCommand); + + assertNotNull(commandMap.getCommand("mock"), "Expected 'mock' command but none was found"); + this.plugin.unloadCommands(); + assertNull(commandMap.getCommand("mock"), "Not expected 'mock' command but some was found"); + } + private void setupPluginManager() { Server server = Bukkit.getServer(); SimpleCommandMap commandMap = new SimpleCommandMap(server); From e66f72dcce63a19590ff6fb4f4f2e7d1fb34df39 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 00:00:56 +0200 Subject: [PATCH 027/204] Refactored code --- example/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index b800bc99..d0663ee0 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -26,7 +26,7 @@ class YAGL extends JavaPlugin { */ void loadCommands() { this.commands.clear() - File commandsDir = new File(getDataFolder(), "commands") + File commandsDir = new File(getDataFolder(), 'commands') if (!commandsDir.exists()) saveDefaultCommands(commandsDir) File[] files = commandsDir.listFiles() if (files != null) @@ -40,8 +40,8 @@ class YAGL extends JavaPlugin { */ void unloadCommands() { commandMap().ifPresent { map -> - Map commands = new Refl<>(map).getFieldObject("knownCommands") - if (commands == null) getLogger().warning("Could not find 'knownCommands' field in CommandMap") + Map commands = new Refl<>(map).getFieldObject('knownCommands') + if (commands == null) getLogger().warning('Could not find \'knownCommands\' field in CommandMap') else commands.keySet().clone().each { key -> Command value = commands.get(key) if (this.commands.contains(value)) commands.remove(key, value) @@ -54,7 +54,7 @@ class YAGL extends JavaPlugin { if (pluginManager == null) Optional.empty() else { def refl = new Refl<>(pluginManager) - Optional.ofNullable(refl.getFieldObject("commandMap")) + Optional.ofNullable(refl.getFieldObject('commandMap')) } } From 83129449c94b2838454c106d2cdb213b9c86d5d4 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 00:04:08 +0200 Subject: [PATCH 028/204] Fixed plugin not invoking real unloadCommands method --- example/src/test/java/it/angrybear/yagl/YAGLTest.java | 1 + 1 file changed, 1 insertion(+) diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/example/src/test/java/it/angrybear/yagl/YAGLTest.java index 7a3bb27d..af32ee84 100644 --- a/example/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/example/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -35,6 +35,7 @@ void setUp() throws IOException { new Refl<>(this.plugin).setFieldObject("commands", new LinkedList<>()); when(this.plugin.getName()).thenReturn("YAGL-Plugin"); doCallRealMethod().when(this.plugin).loadCommands(); + doCallRealMethod().when(this.plugin).unloadCommands(); doCallRealMethod().when(this.plugin).saveDefaultCommands(any()); } From b16b03b272ff95b41a54e7799766e82f0d049c00 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 00:07:02 +0200 Subject: [PATCH 029/204] Fixed CloneNotSupported exception --- example/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index d0663ee0..84d8f04a 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -42,7 +42,7 @@ class YAGL extends JavaPlugin { commandMap().ifPresent { map -> Map commands = new Refl<>(map).getFieldObject('knownCommands') if (commands == null) getLogger().warning('Could not find \'knownCommands\' field in CommandMap') - else commands.keySet().clone().each { key -> + else commands.keySet().collect().each { key -> Command value = commands.get(key) if (this.commands.contains(value)) commands.remove(key, value) } From ffbcba28561a554019e60f6026d082091f516d9a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 00:10:11 +0200 Subject: [PATCH 030/204] Removed unused automatic import statements --- .../groovy/it/angrybear/yagl/commands/ShellCommand.groovy | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy index 774e0236..86e4a4e0 100644 --- a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy @@ -1,8 +1,6 @@ package it.angrybear.yagl.commands import groovy.transform.CompileStatic -import it.angrybear.yagl.YAGL -import it.fulminazzo.fulmicollection.utils.ClassUtils import it.fulminazzo.yamlparser.utils.FileUtils import org.bukkit.command.Command import org.bukkit.command.CommandSender @@ -22,11 +20,8 @@ class ShellCommand extends Command { */ ShellCommand(final @NotNull File file) { super(file.getName().substring(0, file.getName().lastIndexOf('.'))) - def imports = ClassUtils.findClassesInPackage(YAGL.package.name) - .collect({ "import ${it.package.name}.*" }) - .reverse().unique().join("\n") def code = FileUtils.readFileToString(file) - this.shellCode = "${imports}\n${code}\nrun(sender, label, args)" + this.shellCode = "${code}\nrun(sender, label, args)" } @Override From ae8ce3fe11a63d1cc74923d6eb86eaf4774dab71 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 00:13:47 +0200 Subject: [PATCH 031/204] Fixed processResources checking only YAML files --- example/build.gradle | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/example/build.gradle b/example/build.gradle index 92ee7bff..9f589d90 100644 --- a/example/build.gradle +++ b/example/build.gradle @@ -35,5 +35,7 @@ processResources { ] inputs.properties props filteringCharset 'UTF-8' - expand props + filesMatching('*.yml') { + expand props + } } \ No newline at end of file From 300ab0455915977898f2b8b04ef529f36d6cbfea Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 00:21:18 +0200 Subject: [PATCH 032/204] Changed to CompileStatic --- example/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 84d8f04a..f9e90135 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -1,6 +1,7 @@ package it.angrybear.yagl -import groovy.transform.CompileDynamic + +import groovy.transform.CompileStatic import it.angrybear.yagl.commands.ShellCommand import it.fulminazzo.fulmicollection.objects.Refl import it.fulminazzo.yamlparser.utils.FileUtils @@ -10,7 +11,7 @@ import org.bukkit.command.CommandMap import org.bukkit.plugin.java.JavaPlugin import org.jetbrains.annotations.NotNull -@CompileDynamic +@CompileStatic class YAGL extends JavaPlugin { private final List commands = new ArrayList<>() From a4084cb61cf6aeb812abcd75e1ed8b5b4a7563da Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 00:23:52 +0200 Subject: [PATCH 033/204] Fixed saveDefaultCommands not loading all commands --- .../main/groovy/it/angrybear/yagl/YAGL.groovy | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index f9e90135..10548f76 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -67,13 +67,15 @@ class YAGL extends JavaPlugin { void saveDefaultCommands(final @NotNull File commandsDir) { final def containingFolder = '/commands' FileUtils.createFolder(commandsDir) - getClass().getResourceAsStream(containingFolder).withReader { - def fileName = it.readLine() - def file = new File(commandsDir, fileName) - FileUtils.createNewFile(file) - def input = getClass().getResourceAsStream("${containingFolder}/${fileName}") - def output = new FileOutputStream(file) - output << input + getClass().getResourceAsStream(containingFolder).withReader { reader -> + String fileName + while ((fileName = reader.readLine()) != null) { + def file = new File(commandsDir, fileName) + FileUtils.createNewFile(file) + def input = getClass().getResourceAsStream("${containingFolder}/${fileName}") + def output = new FileOutputStream(file) + output << input + } } } From 159b59e1d2ebd528931d4127fb373154c2c366cf Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 00:51:16 +0200 Subject: [PATCH 034/204] Fixed saveDefaultCommands not retrieving commands from Jar files --- .../main/groovy/it/angrybear/yagl/YAGL.groovy | 28 ++++++++++++------- 1 file changed, 18 insertions(+), 10 deletions(-) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 10548f76..328d8ac9 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -1,9 +1,9 @@ package it.angrybear.yagl - import groovy.transform.CompileStatic import it.angrybear.yagl.commands.ShellCommand import it.fulminazzo.fulmicollection.objects.Refl +import it.fulminazzo.fulmicollection.utils.JarUtils import it.fulminazzo.yamlparser.utils.FileUtils import org.bukkit.Bukkit import org.bukkit.command.Command @@ -65,18 +65,26 @@ class YAGL extends JavaPlugin { * @param commandsDir the output directory */ void saveDefaultCommands(final @NotNull File commandsDir) { - final def containingFolder = '/commands' + final def resourceDir = '/commands' FileUtils.createFolder(commandsDir) - getClass().getResourceAsStream(containingFolder).withReader { reader -> + getClass().getResourceAsStream(resourceDir).withReader { reader -> String fileName - while ((fileName = reader.readLine()) != null) { - def file = new File(commandsDir, fileName) - FileUtils.createNewFile(file) - def input = getClass().getResourceAsStream("${containingFolder}/${fileName}") - def output = new FileOutputStream(file) - output << input - } + while ((fileName = reader.readLine()) != null) writeResourceToFile(commandsDir, fileName, resourceDir) + } + Iterator jarEntries = JarUtils.getEntries(YAGL, "") + while (jarEntries.hasNext()) { + def entry = jarEntries.next() + if (entry.startsWith(resourceDir.substring(1)) && entry.length() > resourceDir.length()) + writeResourceToFile(commandsDir, entry.substring(resourceDir.length()), resourceDir) } } + private void writeResourceToFile(final @NotNull File dir, final @NotNull String fileName, final @NotNull resourceDir) { + def file = new File(dir, fileName) + FileUtils.createNewFile(file) + def input = getClass().getResourceAsStream("${resourceDir}/${fileName}") + def output = new FileOutputStream(file) + output << input + } + } From 09d995d121521c59fe1610eeff81a5a3f88b1822 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 00:51:31 +0200 Subject: [PATCH 035/204] Created GetEnchantment command --- .../resources/commands/GetEnchantment.groovy | 26 +++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 example/src/main/resources/commands/GetEnchantment.groovy diff --git a/example/src/main/resources/commands/GetEnchantment.groovy b/example/src/main/resources/commands/GetEnchantment.groovy new file mode 100644 index 00000000..d57179c2 --- /dev/null +++ b/example/src/main/resources/commands/GetEnchantment.groovy @@ -0,0 +1,26 @@ +import it.angrybear.yagl.WrappersAdapter +import it.angrybear.yagl.wrappers.Enchantment +import it.fulminazzo.fulmicollection.structures.Tuple +import org.bukkit.Material +import org.bukkit.entity.Player +import org.bukkit.inventory.ItemStack +import org.bukkit.inventory.meta.EnchantmentStorageMeta + +def run = { sender, label, args -> + if (sender instanceof Player) + if (args.length < 2) + sender.sendMessage('Usage: /getenchantment ') + else + try { + Enchantment enchantment = new Enchantment(args[0], Integer.valueOf(args[1])) + ItemStack book = new ItemStack(Material.ENCHANTED_BOOK) + EnchantmentStorageMeta meta = book.getItemMeta() + Tuple tuple = WrappersAdapter.wEnchantToEnchant(enchantment) + meta.addStoredEnchant(tuple.getKey(), tuple.getValue(), true) + book.setItemMeta(meta) + sender.getInventory().addItem(book) + } catch (NumberFormatException ignored) { + sender.sendMessage("Invalid number '${args[1]}'") + } + else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From 1b4536e055e4fd15929d10bb296289f608648fed Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 12:42:41 +0200 Subject: [PATCH 036/204] Fixed unloadCommands not being called in onDisable --- example/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 328d8ac9..7d964616 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -21,6 +21,11 @@ class YAGL extends JavaPlugin { getLogger().info("Loaded ${commands.size()} commands") } + @Override + void onDisable() { + unloadCommands() + } + /** * Loads all the commands from the {@link #getDataFolder()}/commands directory. * If it does not exist, it is created using {@link #saveDefaultCommands(File)}. From f16fc9b466d701e6e949ba164e813525927ef2c2 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 12:47:58 +0200 Subject: [PATCH 037/204] Refactored code --- .../resources/commands/GetEnchantment.groovy | 25 +++++++++---------- 1 file changed, 12 insertions(+), 13 deletions(-) diff --git a/example/src/main/resources/commands/GetEnchantment.groovy b/example/src/main/resources/commands/GetEnchantment.groovy index d57179c2..42e74f99 100644 --- a/example/src/main/resources/commands/GetEnchantment.groovy +++ b/example/src/main/resources/commands/GetEnchantment.groovy @@ -8,19 +8,18 @@ import org.bukkit.inventory.meta.EnchantmentStorageMeta def run = { sender, label, args -> if (sender instanceof Player) - if (args.length < 2) + try { + Enchantment enchantment = new Enchantment(args[0], Integer.valueOf(args[1])) + ItemStack book = new ItemStack(Material.ENCHANTED_BOOK) + EnchantmentStorageMeta meta = book.getItemMeta() + Tuple tuple = WrappersAdapter.wEnchantToEnchant(enchantment) + meta.addStoredEnchant(tuple.getKey(), tuple.getValue(), true) + book.setItemMeta(meta) + sender.getInventory().addItem(book) + } catch (NumberFormatException ignored) { + sender.sendMessage("Invalid number '${args[1]}'") + } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /getenchantment ') - else - try { - Enchantment enchantment = new Enchantment(args[0], Integer.valueOf(args[1])) - ItemStack book = new ItemStack(Material.ENCHANTED_BOOK) - EnchantmentStorageMeta meta = book.getItemMeta() - Tuple tuple = WrappersAdapter.wEnchantToEnchant(enchantment) - meta.addStoredEnchant(tuple.getKey(), tuple.getValue(), true) - book.setItemMeta(meta) - sender.getInventory().addItem(book) - } catch (NumberFormatException ignored) { - sender.sendMessage("Invalid number '${args[1]}'") - } + } else sender.sendMessage('Console cannot execute this command!') } \ No newline at end of file From 3a0a1be7afc6921b2ab38973fc5f8e6fb807b40a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 12:49:16 +0200 Subject: [PATCH 038/204] Created PlaySound command --- .../src/main/resources/commands/PlaySound.groovy | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) create mode 100644 example/src/main/resources/commands/PlaySound.groovy diff --git a/example/src/main/resources/commands/PlaySound.groovy b/example/src/main/resources/commands/PlaySound.groovy new file mode 100644 index 00000000..527331ef --- /dev/null +++ b/example/src/main/resources/commands/PlaySound.groovy @@ -0,0 +1,16 @@ +import it.angrybear.yagl.WrappersAdapter +import it.angrybear.yagl.wrappers.Sound +import org.bukkit.entity.Player + +def run = { sender, label, args -> + if (sender instanceof Player) { + try { + Sound sound = new Sound(args[0], Float.valueOf(args[1]), Float.valueOf(args[2]), args[3]) + WrappersAdapter.playSound(sender, sound) + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /playsound ') + } catch (Exception e) { + sender.sendMessage(e.getMessage()) + } + } else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From 7de1130a8e87cf67cd4931e0867b7aef41326c7c Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 12:50:02 +0200 Subject: [PATCH 039/204] Created PlayCustomSound command --- .../resources/commands/PlayCustomSound.groovy | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) create mode 100644 example/src/main/resources/commands/PlayCustomSound.groovy diff --git a/example/src/main/resources/commands/PlayCustomSound.groovy b/example/src/main/resources/commands/PlayCustomSound.groovy new file mode 100644 index 00000000..5c3e83da --- /dev/null +++ b/example/src/main/resources/commands/PlayCustomSound.groovy @@ -0,0 +1,16 @@ +import it.angrybear.yagl.WrappersAdapter +import it.angrybear.yagl.wrappers.Sound +import org.bukkit.entity.Player + +def run = { sender, label, args -> + if (sender instanceof Player) { + try { + Sound sound = new Sound(args[0], Float.valueOf(args[1]), Float.valueOf(args[2]), args[3]) + WrappersAdapter.playCustomSound(sender, sound) + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /playsound ') + } catch (Exception e) { + sender.sendMessage(e.getMessage()) + } + } else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From 9472635507f2c637a95871d23a840a9e057628fd Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 12:51:14 +0200 Subject: [PATCH 040/204] Renamed to playyagl to prevent conflict with Minecraft --- .../{PlayCustomSound.groovy => PlayYAGLCustomSound.groovy} | 0 .../resources/commands/{PlaySound.groovy => PlayYAGLSound.groovy} | 0 2 files changed, 0 insertions(+), 0 deletions(-) rename example/src/main/resources/commands/{PlayCustomSound.groovy => PlayYAGLCustomSound.groovy} (100%) rename example/src/main/resources/commands/{PlaySound.groovy => PlayYAGLSound.groovy} (100%) diff --git a/example/src/main/resources/commands/PlayCustomSound.groovy b/example/src/main/resources/commands/PlayYAGLCustomSound.groovy similarity index 100% rename from example/src/main/resources/commands/PlayCustomSound.groovy rename to example/src/main/resources/commands/PlayYAGLCustomSound.groovy diff --git a/example/src/main/resources/commands/PlaySound.groovy b/example/src/main/resources/commands/PlayYAGLSound.groovy similarity index 100% rename from example/src/main/resources/commands/PlaySound.groovy rename to example/src/main/resources/commands/PlayYAGLSound.groovy From b0cbfab2ba59418731cc91c4ce4b1a00dd7055e7 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:08:58 +0200 Subject: [PATCH 041/204] Added number format exception resolution to default error message --- .../it/angrybear/yagl/commands/ShellCommand.groovy | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy index 86e4a4e0..3b547f3c 100644 --- a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy @@ -6,11 +6,15 @@ import org.bukkit.command.Command import org.bukkit.command.CommandSender import org.jetbrains.annotations.NotNull +import java.util.regex.Pattern + /** * A general class used to create a command from a Groovy script. */ @CompileStatic class ShellCommand extends Command { + private static final String NUMBER_FORMAT_REGEX = '(catch *\\(NumberFormatException +ignored\\) *\\{\\n)[ \\t]*(\\n *})' + private static final String INVALID_NUMBER_CODE = 'sender.sendMessage(e.getMessage().replace(\'For input string: \', \'Invalid number \'))' private final String shellCode /** @@ -21,6 +25,11 @@ class ShellCommand extends Command { ShellCommand(final @NotNull File file) { super(file.getName().substring(0, file.getName().lastIndexOf('.'))) def code = FileUtils.readFileToString(file) + def matcher = Pattern.compile(NUMBER_FORMAT_REGEX).matcher(code) + while (matcher.find()) { + def replacement = "${matcher.group(1)} ${INVALID_NUMBER_CODE}${matcher.group(2)}" + code = code.replace(matcher.group(), replacement) + } this.shellCode = "${code}\nrun(sender, label, args)" } From 7b72af012e920a9861e774c2d7c2760d3311babd Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:09:10 +0200 Subject: [PATCH 042/204] Added tests for number format exception resolution --- .../yagl/commands/ShellCommandTest.java | 19 +++++++++++++++++++ .../number-format-exception-command.groovy | 7 +++++++ 2 files changed, 26 insertions(+) create mode 100644 example/src/test/resources/number-format-exception-command.groovy diff --git a/example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java b/example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java index 7be883b5..6d3f1989 100644 --- a/example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java +++ b/example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java @@ -1,5 +1,6 @@ package it.angrybear.yagl.commands; +import it.fulminazzo.fulmicollection.objects.Refl; import org.bukkit.command.CommandSender; import org.junit.jupiter.api.Test; @@ -29,4 +30,22 @@ void testExecute() { assertEquals("Hello world", message.get()); } + @Test + void testNumberFormatExceptionReplacement() { + String expected = "def run = { sender, label, args ->\n" + + " try {\n" + + " sender.sendMessage(\"Your number is ${Integer.valueOf(args[0])}\")\n" + + " } catch (NumberFormatException ignored) {\n" + + " sender.sendMessage(e.getMessage().replace('For input string: ', 'Invalid number '))\n" + + " }\n" + + "}\n" + + "run(sender, label, args)"; + File file = new File("build/resources/test/number-format-exception-command.groovy"); + + ShellCommand shellCommand = new ShellCommand(file); + String actual = new Refl<>(shellCommand).getFieldObject("shellCode"); + + assertEquals(expected, actual); + } + } \ No newline at end of file diff --git a/example/src/test/resources/number-format-exception-command.groovy b/example/src/test/resources/number-format-exception-command.groovy new file mode 100644 index 00000000..ab77e553 --- /dev/null +++ b/example/src/test/resources/number-format-exception-command.groovy @@ -0,0 +1,7 @@ +def run = { sender, label, args -> + try { + sender.sendMessage("Your number is ${Integer.valueOf(args[0])}") + } catch (NumberFormatException ignored) { + + } +} \ No newline at end of file From 6a12c46809f38ab8e1204c4006ce8d322e9348af Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:10:03 +0200 Subject: [PATCH 043/204] Replaced NumberFormatExceptions --- example/src/main/resources/commands/GetEnchantment.groovy | 2 +- example/src/main/resources/commands/PlayYAGLCustomSound.groovy | 2 ++ example/src/main/resources/commands/PlayYAGLSound.groovy | 2 ++ 3 files changed, 5 insertions(+), 1 deletion(-) diff --git a/example/src/main/resources/commands/GetEnchantment.groovy b/example/src/main/resources/commands/GetEnchantment.groovy index 42e74f99..adea3eb3 100644 --- a/example/src/main/resources/commands/GetEnchantment.groovy +++ b/example/src/main/resources/commands/GetEnchantment.groovy @@ -17,7 +17,7 @@ def run = { sender, label, args -> book.setItemMeta(meta) sender.getInventory().addItem(book) } catch (NumberFormatException ignored) { - sender.sendMessage("Invalid number '${args[1]}'") + } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /getenchantment ') } diff --git a/example/src/main/resources/commands/PlayYAGLCustomSound.groovy b/example/src/main/resources/commands/PlayYAGLCustomSound.groovy index 5c3e83da..fb4143c7 100644 --- a/example/src/main/resources/commands/PlayYAGLCustomSound.groovy +++ b/example/src/main/resources/commands/PlayYAGLCustomSound.groovy @@ -9,6 +9,8 @@ def run = { sender, label, args -> WrappersAdapter.playCustomSound(sender, sound) } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /playsound ') + } catch (NumberFormatException ignored) { + } catch (Exception e) { sender.sendMessage(e.getMessage()) } diff --git a/example/src/main/resources/commands/PlayYAGLSound.groovy b/example/src/main/resources/commands/PlayYAGLSound.groovy index 527331ef..d7600a62 100644 --- a/example/src/main/resources/commands/PlayYAGLSound.groovy +++ b/example/src/main/resources/commands/PlayYAGLSound.groovy @@ -9,6 +9,8 @@ def run = { sender, label, args -> WrappersAdapter.playSound(sender, sound) } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /playsound ') + } catch (NumberFormatException ignored) { + } catch (Exception e) { sender.sendMessage(e.getMessage()) } From c335b45cd1893132fad4b4ffcb64b13b0c9ebbab Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:11:43 +0200 Subject: [PATCH 044/204] Fixed ShellCommand not checking for null or empty code --- .../groovy/it/angrybear/yagl/commands/ShellCommand.groovy | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy index 3b547f3c..d89db548 100644 --- a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy @@ -25,6 +25,10 @@ class ShellCommand extends Command { ShellCommand(final @NotNull File file) { super(file.getName().substring(0, file.getName().lastIndexOf('.'))) def code = FileUtils.readFileToString(file) + if (code == null) { + this.shellCode = '' + return + } def matcher = Pattern.compile(NUMBER_FORMAT_REGEX).matcher(code) while (matcher.find()) { def replacement = "${matcher.group(1)} ${INVALID_NUMBER_CODE}${matcher.group(2)}" From ce6f69eb44960a6ae4da63915142bb2b755176cd Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:14:25 +0200 Subject: [PATCH 045/204] Created ApplyPotionEffect command --- .../commands/ApplyPotionEffect.groovy | 20 +++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 example/src/main/resources/commands/ApplyPotionEffect.groovy diff --git a/example/src/main/resources/commands/ApplyPotionEffect.groovy b/example/src/main/resources/commands/ApplyPotionEffect.groovy new file mode 100644 index 00000000..b0f20a0f --- /dev/null +++ b/example/src/main/resources/commands/ApplyPotionEffect.groovy @@ -0,0 +1,20 @@ +import it.angrybear.yagl.WrappersAdapter +import it.angrybear.yagl.wrappers.PotionEffect +import org.bukkit.entity.Player + +def run = { sender, label, args -> + if (sender instanceof Player) { + try { + PotionEffect effect = new PotionEffect(args[0], Double.valueOf(args[1]), + Integer.valueOf(args[2]), Boolean.valueOf(args[3]), Boolean.valueOf(args[4])) + def potionEffect = WrappersAdapter.wPotionEffectToPotionEffect(effect) + sender.addPotionEffect(potionEffect) + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /applypotioneffect ') + } catch (NumberFormatException ignored) { + + } catch (Exception e) { + sender.sendMessage(e.getMessage()) + } + } else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From 8fee4f272b794b45f230b43a39e40a77389f86c5 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:21:31 +0200 Subject: [PATCH 046/204] Extracted parseWrapperFromString method --- .../yagl/wrappers/WrapperParser.java | 29 +++++++++++++------ 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/wrappers/serializer/src/main/java/it/angrybear/yagl/wrappers/WrapperParser.java b/wrappers/serializer/src/main/java/it/angrybear/yagl/wrappers/WrapperParser.java index f39c47d9..8c2f59e2 100644 --- a/wrappers/serializer/src/main/java/it/angrybear/yagl/wrappers/WrapperParser.java +++ b/wrappers/serializer/src/main/java/it/angrybear/yagl/wrappers/WrapperParser.java @@ -38,24 +38,35 @@ protected BiFunctionException getLoader() { return (c, s) -> { String raw = c.getString(s); if (raw == null || raw.trim().isEmpty()) return null; - else { - String[] rawData = raw.split(":"); - Constructor constructor = findConstructorFromRaw(rawData); - Object[] parameters = initializeParameters(rawData, constructor); - return new Refl<>(getOClass(), parameters).getObject(); - } + else return parseWrapperFromString(raw, getOClass()); }; } - private @NotNull Constructor findConstructorFromRaw(final String @NotNull [] rawData) throws NoSuchMethodException { - Constructor constructor = (Constructor) Arrays.stream(getOClass().getConstructors()) + /** + * Converts the given string to an instance of the given wrapper class by using the most appropriate constructor. + * + * @param the type of the wrapper + * @param raw the string to convert from + * @param clazz the class of the wrapper + * @return the wrapper + * @throws NoSuchMethodException an exception thrown in case the constructor cannot be found + */ + public static @NotNull W parseWrapperFromString(final @NotNull String raw, final @NotNull Class clazz) throws NoSuchMethodException { + String[] rawData = raw.split(":"); + Constructor constructor = findConstructorFromRaw(rawData, clazz); + Object[] parameters = initializeParameters(rawData, constructor); + return new Refl<>(clazz, parameters).getObject(); + } + + private static @NotNull Constructor findConstructorFromRaw(final String @NotNull [] rawData, final @NotNull Class clazz) throws NoSuchMethodException { + Constructor constructor = (Constructor) Arrays.stream(clazz.getConstructors()) .filter(t -> t.getParameterCount() <= rawData.length) .min(Comparator.comparing(t -> -t.getParameterCount())).orElse(null); if (constructor == null) { StringBuilder builder = new StringBuilder(); for (int i = 0; i < rawData.length; i++) builder.append("?, "); throw new NoSuchMethodException(String.format("Could not find method %s(%s)", - getOClass().getSimpleName(), builder.substring(0, Math.max(0, builder.length() - 2)))); + clazz.getSimpleName(), builder.substring(0, Math.max(0, builder.length() - 2)))); } return constructor; } From 03a423f0eb06dbed2c35c62066ed5b6a923e9fd4 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:25:18 +0200 Subject: [PATCH 047/204] Created PlayParticle method with no option recognition --- .../resources/commands/PlayParticle.groovy | 23 +++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 example/src/main/resources/commands/PlayParticle.groovy diff --git a/example/src/main/resources/commands/PlayParticle.groovy b/example/src/main/resources/commands/PlayParticle.groovy new file mode 100644 index 00000000..6728ebdc --- /dev/null +++ b/example/src/main/resources/commands/PlayParticle.groovy @@ -0,0 +1,23 @@ +import it.angrybear.yagl.WrappersAdapter +import it.angrybear.yagl.particles.Particle +import it.angrybear.yagl.particles.ParticleType +import org.bukkit.entity.Player + +def run = { sender, label, args -> + if (sender instanceof Player) { + try { + ParticleType type = ParticleType.valueOf(args[0]) + Particle particle + if (args.length > 1) { + + } else particle = type.create() + WrappersAdapter.spawnParticle(sender, particle, sender.getEyeLocation(), 1) + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /playparticle ') + } catch (NumberFormatException ignored) { + + } catch (Exception e) { + sender.sendMessage(e.getMessage()) + } + } else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From 1dc008eb77923990689643f855c844c988e17191 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:48:51 +0200 Subject: [PATCH 048/204] Fixed ItemAdapter not checking for custom model data --- item/bukkit/src/main/java/it/angrybear/yagl/ItemAdapter.java | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/item/bukkit/src/main/java/it/angrybear/yagl/ItemAdapter.java b/item/bukkit/src/main/java/it/angrybear/yagl/ItemAdapter.java index f6e8f44d..4f4c3e49 100644 --- a/item/bukkit/src/main/java/it/angrybear/yagl/ItemAdapter.java +++ b/item/bukkit/src/main/java/it/angrybear/yagl/ItemAdapter.java @@ -56,8 +56,7 @@ public final class ItemAdapter { invokeNoSuchMethod(() -> item.setUnbreakable(meta.isUnbreakable()), () -> item.setUnbreakable(meta.spigot().isUnbreakable())); invokeNoSuchMethod(() -> { - int modelData = meta.getCustomModelData(); - if (modelData > 0) item.setCustomModelData(modelData); + if (meta.hasCustomModelData()) item.setCustomModelData(meta.getCustomModelData()); }, null); } return item; From d7550c0b6018691a79e6ef623c4b49da4d5b9ce0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:50:06 +0200 Subject: [PATCH 049/204] Updated WrappersAdapter reference to ItemAdapter --- .../src/main/java/it/angrybear/yagl/WrappersAdapter.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java b/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java index a441615c..26d11ebc 100644 --- a/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java +++ b/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java @@ -425,9 +425,9 @@ else if (dataType.getCanonicalName().equals("org.bukkit.block.data.BlockData")) public static @Nullable ItemStack itemToItemStack(final @Nullable AbstractItem item) { final Class itemUtils; try { - itemUtils = ReflectionUtils.getClass("it.angrybear.yagl.utils.ItemUtils"); + itemUtils = ReflectionUtils.getClass("it.angrybear.yagl.ItemAdapter"); } catch (IllegalArgumentException e) { - throw new IllegalStateException("Could not find ItemUtils class. This function requires the 'item:bukkit' module to be added"); + throw new IllegalStateException("Could not find ItemAdapter class. This function requires the 'item:bukkit' module to be added"); } return new Refl<>(itemUtils).invokeMethod("itemToItemStack", item); } From 608456f04a529d84466c0d4eb007b02fed26fae8 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:55:11 +0200 Subject: [PATCH 050/204] Added getOption method to convert options passed by players --- .../resources/commands/PlayParticle.groovy | 25 ++++++++++++++++--- 1 file changed, 21 insertions(+), 4 deletions(-) diff --git a/example/src/main/resources/commands/PlayParticle.groovy b/example/src/main/resources/commands/PlayParticle.groovy index 6728ebdc..e3826aea 100644 --- a/example/src/main/resources/commands/PlayParticle.groovy +++ b/example/src/main/resources/commands/PlayParticle.groovy @@ -1,15 +1,32 @@ +import it.angrybear.yagl.Color +import it.angrybear.yagl.ItemAdapter import it.angrybear.yagl.WrappersAdapter -import it.angrybear.yagl.particles.Particle -import it.angrybear.yagl.particles.ParticleType +import it.angrybear.yagl.particles.* +import it.fulminazzo.fulmicollection.objects.Refl import org.bukkit.entity.Player +import org.bukkit.inventory.EquipmentSlot + +def getOption(sender, particleType, optionType, args) { + if (optionType == DustParticleOption) + new DustParticleOption(Color.fromARGB(args[0]), Float.valueOf(args[1])) + if (optionType == DustTransitionParticleOption) + new DustTransitionParticleOption(Color.fromARGB(args[0]), Color.fromARGB(args[1]), Float.valueOf(args[2])) + else if (optionType == ItemParticleOption) + ItemAdapter.itemStackToItem(sender.getInventory().getItem(EquipmentSlot.HAND)) + else if (optionType == BlockDataOption) + new BlockDataOption(args[0]) + throw new IllegalArgumentException("Cannot get particle option of ${optionType}") +} def run = { sender, label, args -> if (sender instanceof Player) { try { ParticleType type = ParticleType.valueOf(args[0]) + Class optionType = new Refl<>(type).getFieldObject('optionType') Particle particle - if (args.length > 1) { - + if (args.length > 1 && optionType != null) { + def option = getOption(sender, type, optionType, Arrays.copyOfRange(args, 1, args.length)) + particle = type.create(option) } else particle = type.create() WrappersAdapter.spawnParticle(sender, particle, sender.getEyeLocation(), 1) } catch (IndexOutOfBoundsException ignored) { From 6c06895b9bf08323648e0e6969d0fc2f2ded92d3 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 13:57:42 +0200 Subject: [PATCH 051/204] Added recognition for primitive particle options --- example/src/main/resources/commands/PlayParticle.groovy | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/example/src/main/resources/commands/PlayParticle.groovy b/example/src/main/resources/commands/PlayParticle.groovy index e3826aea..ea4c9445 100644 --- a/example/src/main/resources/commands/PlayParticle.groovy +++ b/example/src/main/resources/commands/PlayParticle.groovy @@ -15,6 +15,10 @@ def getOption(sender, particleType, optionType, args) { ItemAdapter.itemStackToItem(sender.getInventory().getItem(EquipmentSlot.HAND)) else if (optionType == BlockDataOption) new BlockDataOption(args[0]) + else if (particleType == ParticleType.SCULK_CHARGE) + new PrimitiveParticleOption<>(Float.valueOf(args[0])) + else if (particleType == ParticleType.SHRIEK) + new PrimitiveParticleOption<>(Integer.valueOf(args[0])) throw new IllegalArgumentException("Cannot get particle option of ${optionType}") } From da2b24936a0d0c6f838ca852a95652e25b425288 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 14:00:45 +0200 Subject: [PATCH 052/204] Fixed illegal argument exception --- example/src/main/resources/commands/PlayParticle.groovy | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/example/src/main/resources/commands/PlayParticle.groovy b/example/src/main/resources/commands/PlayParticle.groovy index ea4c9445..562cb5d9 100644 --- a/example/src/main/resources/commands/PlayParticle.groovy +++ b/example/src/main/resources/commands/PlayParticle.groovy @@ -19,7 +19,7 @@ def getOption(sender, particleType, optionType, args) { new PrimitiveParticleOption<>(Float.valueOf(args[0])) else if (particleType == ParticleType.SHRIEK) new PrimitiveParticleOption<>(Integer.valueOf(args[0])) - throw new IllegalArgumentException("Cannot get particle option of ${optionType}") + else throw new IllegalArgumentException("Cannot get particle option of ${optionType}") } def run = { sender, label, args -> From 796f352eb1b9e9a3feca4c98ba6b655535aba9bd Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 14:02:26 +0200 Subject: [PATCH 053/204] Added vibration particle --- .../src/main/resources/commands/PlayParticle.groovy | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/example/src/main/resources/commands/PlayParticle.groovy b/example/src/main/resources/commands/PlayParticle.groovy index 562cb5d9..fd5f0338 100644 --- a/example/src/main/resources/commands/PlayParticle.groovy +++ b/example/src/main/resources/commands/PlayParticle.groovy @@ -3,6 +3,7 @@ import it.angrybear.yagl.ItemAdapter import it.angrybear.yagl.WrappersAdapter import it.angrybear.yagl.particles.* import it.fulminazzo.fulmicollection.objects.Refl +import org.bukkit.Location import org.bukkit.entity.Player import org.bukkit.inventory.EquipmentSlot @@ -12,10 +13,15 @@ def getOption(sender, particleType, optionType, args) { if (optionType == DustTransitionParticleOption) new DustTransitionParticleOption(Color.fromARGB(args[0]), Color.fromARGB(args[1]), Float.valueOf(args[2])) else if (optionType == ItemParticleOption) - ItemAdapter.itemStackToItem(sender.getInventory().getItem(EquipmentSlot.HAND)) + ItemAdapter.itemStackToItem(sender.inventory.getItem(EquipmentSlot.HAND)) else if (optionType == BlockDataOption) new BlockDataOption(args[0]) - else if (particleType == ParticleType.SCULK_CHARGE) + else if (particleType == ParticleType.VIBRATION) { + Location start = sender.location + Location end = start.clone().add(0, 10, 0) + def dest = new org.bukkit.Vibration.Destination.BlockDestination(end) + new PrimitiveParticleOption<>(new org.bukkit.Vibration(start, dest, Integer.valueOf(args[0]))) + } else if (particleType == ParticleType.SCULK_CHARGE) new PrimitiveParticleOption<>(Float.valueOf(args[0])) else if (particleType == ParticleType.SHRIEK) new PrimitiveParticleOption<>(Integer.valueOf(args[0])) From 01222a760a41b98574b73faa4a5058d8349f29ac Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 14:08:56 +0200 Subject: [PATCH 054/204] Created PlayEffect command with primitive particle types initialized --- .../main/resources/commands/PlayEffect.groovy | 44 +++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 example/src/main/resources/commands/PlayEffect.groovy diff --git a/example/src/main/resources/commands/PlayEffect.groovy b/example/src/main/resources/commands/PlayEffect.groovy new file mode 100644 index 00000000..a4df96e8 --- /dev/null +++ b/example/src/main/resources/commands/PlayEffect.groovy @@ -0,0 +1,44 @@ +import it.angrybear.yagl.WrappersAdapter +import it.angrybear.yagl.particles.LegacyParticleType +import it.angrybear.yagl.particles.Particle +import it.angrybear.yagl.particles.PrimitiveParticleOption +import it.fulminazzo.fulmicollection.objects.Refl +import org.bukkit.entity.Player + +def getOption(sender, particleType, optionType, args) { + if (optionType); + else if (particleType == LegacyParticleType.SMOKE) + new PrimitiveParticleOption<>(args[0]) + else if (particleType == LegacyParticleType.VILLAGER_PLANT_GROW) + new PrimitiveParticleOption<>(Integer.valueOf(args[0])) + else if (particleType == LegacyParticleType.ITEM_BREAK) + new PrimitiveParticleOption<>(args[0]) + else if (particleType == LegacyParticleType.COMPOSTER_FILL_ATTEMPT) + new PrimitiveParticleOption<>(Boolean.valueOf(args[0])) + else if (particleType == LegacyParticleType.BONE_MEAL_USE) + new PrimitiveParticleOption<>(Integer.valueOf(args[0])) + else if (particleType == LegacyParticleType.ELECTRIC_SPARK) + new PrimitiveParticleOption<>(args[0]) + else throw new IllegalArgumentException("Cannot get particle option of ${optionType}") +} + +def run = { sender, label, args -> + if (sender instanceof Player) { + try { + LegacyParticleType type = LegacyParticleType.valueOf(args[0]) + Class optionType = new Refl<>(type).getFieldObject('optionType') + Particle particle + if (args.length > 1 && optionType != null) { + def option = getOption(sender, type, optionType, Arrays.copyOfRange(args, 1, args.length)) + particle = type.create(option) + } else particle = type.create() + WrappersAdapter.spawnParticle(sender, particle, sender.getEyeLocation(), 1) + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /playeffect ') + } catch (NumberFormatException ignored) { + + } catch (Exception e) { + sender.sendMessage(e.getMessage()) + } + } else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From 83a172b72bcd4325abe95cb4c25c4eacf63b75ad Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 14:10:35 +0200 Subject: [PATCH 055/204] Added missing option types --- .../src/main/resources/commands/PlayEffect.groovy | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/example/src/main/resources/commands/PlayEffect.groovy b/example/src/main/resources/commands/PlayEffect.groovy index a4df96e8..55e1a254 100644 --- a/example/src/main/resources/commands/PlayEffect.groovy +++ b/example/src/main/resources/commands/PlayEffect.groovy @@ -1,12 +1,23 @@ +import it.angrybear.yagl.Color import it.angrybear.yagl.WrappersAdapter +import it.angrybear.yagl.particles.ColorParticleOption import it.angrybear.yagl.particles.LegacyParticleType +import it.angrybear.yagl.particles.MaterialDataOption import it.angrybear.yagl.particles.Particle +import it.angrybear.yagl.particles.PotionParticleOption import it.angrybear.yagl.particles.PrimitiveParticleOption +import it.angrybear.yagl.wrappers.Potion import it.fulminazzo.fulmicollection.objects.Refl import org.bukkit.entity.Player def getOption(sender, particleType, optionType, args) { - if (optionType); + if (optionType == PotionParticleOption) + new PotionParticleOption(new Potion(args[0], Integer.valueOf(args[1]), + Boolean.valueOf(args[2]), Boolean.valueOf(args[3]))) + else if (optionType == MaterialDataOption) + new MaterialDataOption(args[0]) + else if (optionType == ColorParticleOption) + new ColorParticleOption(Color.fromARGB(args[0])) else if (particleType == LegacyParticleType.SMOKE) new PrimitiveParticleOption<>(args[0]) else if (particleType == LegacyParticleType.VILLAGER_PLANT_GROW) From baf5cbce76f5609d14b43182f83f32b1259cfd5f Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 14:11:37 +0200 Subject: [PATCH 056/204] Fixed PlayEffect not using WrappersAdapter#spawnEffect --- example/src/main/resources/commands/PlayEffect.groovy | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/example/src/main/resources/commands/PlayEffect.groovy b/example/src/main/resources/commands/PlayEffect.groovy index 55e1a254..c16aa6f2 100644 --- a/example/src/main/resources/commands/PlayEffect.groovy +++ b/example/src/main/resources/commands/PlayEffect.groovy @@ -43,7 +43,7 @@ def run = { sender, label, args -> def option = getOption(sender, type, optionType, Arrays.copyOfRange(args, 1, args.length)) particle = type.create(option) } else particle = type.create() - WrappersAdapter.spawnParticle(sender, particle, sender.getEyeLocation(), 1) + WrappersAdapter.spawnEffect(sender, particle, sender.getEyeLocation()) } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /playeffect ') } catch (NumberFormatException ignored) { From 2765ea258dd7955f4cc7b577a454bfee3f941fa0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 14:11:37 +0200 Subject: [PATCH 057/204] Fixed PlayEffect not using WrappersAdapter#spawnEffect --- example/src/main/resources/commands/PlayEffect.groovy | 9 ++------- 1 file changed, 2 insertions(+), 7 deletions(-) diff --git a/example/src/main/resources/commands/PlayEffect.groovy b/example/src/main/resources/commands/PlayEffect.groovy index 55e1a254..1f0f5235 100644 --- a/example/src/main/resources/commands/PlayEffect.groovy +++ b/example/src/main/resources/commands/PlayEffect.groovy @@ -1,11 +1,6 @@ import it.angrybear.yagl.Color import it.angrybear.yagl.WrappersAdapter -import it.angrybear.yagl.particles.ColorParticleOption -import it.angrybear.yagl.particles.LegacyParticleType -import it.angrybear.yagl.particles.MaterialDataOption -import it.angrybear.yagl.particles.Particle -import it.angrybear.yagl.particles.PotionParticleOption -import it.angrybear.yagl.particles.PrimitiveParticleOption +import it.angrybear.yagl.particles.* import it.angrybear.yagl.wrappers.Potion import it.fulminazzo.fulmicollection.objects.Refl import org.bukkit.entity.Player @@ -43,7 +38,7 @@ def run = { sender, label, args -> def option = getOption(sender, type, optionType, Arrays.copyOfRange(args, 1, args.length)) particle = type.create(option) } else particle = type.create() - WrappersAdapter.spawnParticle(sender, particle, sender.getEyeLocation(), 1) + WrappersAdapter.spawnEffect(sender, particle, sender.getEyeLocation()) } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /playeffect ') } catch (NumberFormatException ignored) { From f47e3d3142a2fc722cb26f4270e86b3358570cdc Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 14:16:48 +0200 Subject: [PATCH 058/204] Added documentation --- example/src/main/resources/commands/PlayEffect.groovy | 6 ++++++ example/src/main/resources/commands/PlayParticle.groovy | 6 ++++++ 2 files changed, 12 insertions(+) diff --git a/example/src/main/resources/commands/PlayEffect.groovy b/example/src/main/resources/commands/PlayEffect.groovy index 1f0f5235..2b75c516 100644 --- a/example/src/main/resources/commands/PlayEffect.groovy +++ b/example/src/main/resources/commands/PlayEffect.groovy @@ -1,3 +1,9 @@ +/** + * Spawns the specified particle at the player's eyes location. + * If additional arguments are specified, and the particle supports it, + * they are converted to the corresponding ParticleOption. + * See {@link #getOption(Object, Object, Object, Object)} to find out how. + */ import it.angrybear.yagl.Color import it.angrybear.yagl.WrappersAdapter import it.angrybear.yagl.particles.* diff --git a/example/src/main/resources/commands/PlayParticle.groovy b/example/src/main/resources/commands/PlayParticle.groovy index fd5f0338..e4d1ec6b 100644 --- a/example/src/main/resources/commands/PlayParticle.groovy +++ b/example/src/main/resources/commands/PlayParticle.groovy @@ -1,3 +1,9 @@ +/** + * Spawns the specified particle at the player's eyes location. + * If additional arguments are specified, and the particle supports it, + * they are converted to the corresponding ParticleOption. + * See {@link #getOption(Object, Object, Object, Object)} to find out how. + */ import it.angrybear.yagl.Color import it.angrybear.yagl.ItemAdapter import it.angrybear.yagl.WrappersAdapter From 9ee11193f02aaefdc745a050b1c9d8b434614ef6 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Sun, 14 Apr 2024 14:18:15 +0200 Subject: [PATCH 059/204] Added filter for file names ending with .groovy --- example/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 7d964616..09444807 100644 --- a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -36,7 +36,7 @@ class YAGL extends JavaPlugin { if (!commandsDir.exists()) saveDefaultCommands(commandsDir) File[] files = commandsDir.listFiles() if (files != null) - this.commands.addAll(files.collect { new ShellCommand(it) }) + this.commands.addAll(files.findAll({ it.name.endsWith(".groovy") }).collect { new ShellCommand(it) }) commandMap().ifPresent { map -> this.commands.each { map.register(getName(), it) } } } From 4e6931ce0d225cd4da8991ec838f0eb8ddcbabe9 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 00:13:48 +0200 Subject: [PATCH 060/204] Renamed example module to demo --- {example => demo}/build.gradle | 0 {example => demo}/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 0 .../main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy | 0 .../src/main/resources/commands/ApplyPotionEffect.groovy | 0 .../src/main/resources/commands/GetEnchantment.groovy | 0 {example => demo}/src/main/resources/commands/PlayEffect.groovy | 0 .../src/main/resources/commands/PlayParticle.groovy | 0 .../src/main/resources/commands/PlayYAGLCustomSound.groovy | 0 .../src/main/resources/commands/PlayYAGLSound.groovy | 0 {example => demo}/src/main/resources/plugin.yml | 0 {example => demo}/src/test/java/it/angrybear/yagl/YAGLTest.java | 0 .../test/java/it/angrybear/yagl/commands/ShellCommandTest.java | 0 {example => demo}/src/test/resources/commands/mock.groovy | 0 .../src/test/resources/number-format-exception-command.groovy | 0 {example => demo}/src/test/resources/shell-command.groovy | 0 settings.gradle | 2 +- 16 files changed, 1 insertion(+), 1 deletion(-) rename {example => demo}/build.gradle (100%) rename {example => demo}/src/main/groovy/it/angrybear/yagl/YAGL.groovy (100%) rename {example => demo}/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy (100%) rename {example => demo}/src/main/resources/commands/ApplyPotionEffect.groovy (100%) rename {example => demo}/src/main/resources/commands/GetEnchantment.groovy (100%) rename {example => demo}/src/main/resources/commands/PlayEffect.groovy (100%) rename {example => demo}/src/main/resources/commands/PlayParticle.groovy (100%) rename {example => demo}/src/main/resources/commands/PlayYAGLCustomSound.groovy (100%) rename {example => demo}/src/main/resources/commands/PlayYAGLSound.groovy (100%) rename {example => demo}/src/main/resources/plugin.yml (100%) rename {example => demo}/src/test/java/it/angrybear/yagl/YAGLTest.java (100%) rename {example => demo}/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java (100%) rename {example => demo}/src/test/resources/commands/mock.groovy (100%) rename {example => demo}/src/test/resources/number-format-exception-command.groovy (100%) rename {example => demo}/src/test/resources/shell-command.groovy (100%) diff --git a/example/build.gradle b/demo/build.gradle similarity index 100% rename from example/build.gradle rename to demo/build.gradle diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy similarity index 100% rename from example/src/main/groovy/it/angrybear/yagl/YAGL.groovy rename to demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy diff --git a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy similarity index 100% rename from example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy rename to demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy diff --git a/example/src/main/resources/commands/ApplyPotionEffect.groovy b/demo/src/main/resources/commands/ApplyPotionEffect.groovy similarity index 100% rename from example/src/main/resources/commands/ApplyPotionEffect.groovy rename to demo/src/main/resources/commands/ApplyPotionEffect.groovy diff --git a/example/src/main/resources/commands/GetEnchantment.groovy b/demo/src/main/resources/commands/GetEnchantment.groovy similarity index 100% rename from example/src/main/resources/commands/GetEnchantment.groovy rename to demo/src/main/resources/commands/GetEnchantment.groovy diff --git a/example/src/main/resources/commands/PlayEffect.groovy b/demo/src/main/resources/commands/PlayEffect.groovy similarity index 100% rename from example/src/main/resources/commands/PlayEffect.groovy rename to demo/src/main/resources/commands/PlayEffect.groovy diff --git a/example/src/main/resources/commands/PlayParticle.groovy b/demo/src/main/resources/commands/PlayParticle.groovy similarity index 100% rename from example/src/main/resources/commands/PlayParticle.groovy rename to demo/src/main/resources/commands/PlayParticle.groovy diff --git a/example/src/main/resources/commands/PlayYAGLCustomSound.groovy b/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy similarity index 100% rename from example/src/main/resources/commands/PlayYAGLCustomSound.groovy rename to demo/src/main/resources/commands/PlayYAGLCustomSound.groovy diff --git a/example/src/main/resources/commands/PlayYAGLSound.groovy b/demo/src/main/resources/commands/PlayYAGLSound.groovy similarity index 100% rename from example/src/main/resources/commands/PlayYAGLSound.groovy rename to demo/src/main/resources/commands/PlayYAGLSound.groovy diff --git a/example/src/main/resources/plugin.yml b/demo/src/main/resources/plugin.yml similarity index 100% rename from example/src/main/resources/plugin.yml rename to demo/src/main/resources/plugin.yml diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java similarity index 100% rename from example/src/test/java/it/angrybear/yagl/YAGLTest.java rename to demo/src/test/java/it/angrybear/yagl/YAGLTest.java diff --git a/example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java b/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java similarity index 100% rename from example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java rename to demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java diff --git a/example/src/test/resources/commands/mock.groovy b/demo/src/test/resources/commands/mock.groovy similarity index 100% rename from example/src/test/resources/commands/mock.groovy rename to demo/src/test/resources/commands/mock.groovy diff --git a/example/src/test/resources/number-format-exception-command.groovy b/demo/src/test/resources/number-format-exception-command.groovy similarity index 100% rename from example/src/test/resources/number-format-exception-command.groovy rename to demo/src/test/resources/number-format-exception-command.groovy diff --git a/example/src/test/resources/shell-command.groovy b/demo/src/test/resources/shell-command.groovy similarity index 100% rename from example/src/test/resources/shell-command.groovy rename to demo/src/test/resources/shell-command.groovy diff --git a/settings.gradle b/settings.gradle index 32268302..4da565f9 100644 --- a/settings.gradle +++ b/settings.gradle @@ -43,6 +43,7 @@ include 'gui:gui-serializer' project(':gui:gui-serializer').projectDir = file('gui/serializer') include 'testing' +include 'demo' gradleEnterprise { if (System.getenv("CI") != null) { @@ -53,5 +54,4 @@ gradleEnterprise { } } } -include 'example' From 49189e7ce1c03af2a144fd655251d7b5fa47994f Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 00:13:48 +0200 Subject: [PATCH 061/204] Renamed example module to demo --- build.gradle | 4 ++-- {example => demo}/build.gradle | 0 .../src/main/groovy/it/angrybear/yagl/YAGL.groovy | 0 .../groovy/it/angrybear/yagl/commands/ShellCommand.groovy | 0 .../src/main/resources/commands/ApplyPotionEffect.groovy | 0 .../src/main/resources/commands/GetEnchantment.groovy | 0 .../src/main/resources/commands/PlayEffect.groovy | 0 .../src/main/resources/commands/PlayParticle.groovy | 0 .../src/main/resources/commands/PlayYAGLCustomSound.groovy | 0 .../src/main/resources/commands/PlayYAGLSound.groovy | 0 {example => demo}/src/main/resources/plugin.yml | 0 .../src/test/java/it/angrybear/yagl/YAGLTest.java | 0 .../java/it/angrybear/yagl/commands/ShellCommandTest.java | 0 {example => demo}/src/test/resources/commands/mock.groovy | 0 .../src/test/resources/number-format-exception-command.groovy | 0 {example => demo}/src/test/resources/shell-command.groovy | 0 settings.gradle | 2 +- 17 files changed, 3 insertions(+), 3 deletions(-) rename {example => demo}/build.gradle (100%) rename {example => demo}/src/main/groovy/it/angrybear/yagl/YAGL.groovy (100%) rename {example => demo}/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy (100%) rename {example => demo}/src/main/resources/commands/ApplyPotionEffect.groovy (100%) rename {example => demo}/src/main/resources/commands/GetEnchantment.groovy (100%) rename {example => demo}/src/main/resources/commands/PlayEffect.groovy (100%) rename {example => demo}/src/main/resources/commands/PlayParticle.groovy (100%) rename {example => demo}/src/main/resources/commands/PlayYAGLCustomSound.groovy (100%) rename {example => demo}/src/main/resources/commands/PlayYAGLSound.groovy (100%) rename {example => demo}/src/main/resources/plugin.yml (100%) rename {example => demo}/src/test/java/it/angrybear/yagl/YAGLTest.java (100%) rename {example => demo}/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java (100%) rename {example => demo}/src/test/resources/commands/mock.groovy (100%) rename {example => demo}/src/test/resources/number-format-exception-command.groovy (100%) rename {example => demo}/src/test/resources/shell-command.groovy (100%) diff --git a/build.gradle b/build.gradle index 3b4db612..bbc85aab 100644 --- a/build.gradle +++ b/build.gradle @@ -9,7 +9,7 @@ group = 'it.angrybear' version = '4.0' final def TEST_MODULE = "testing" -final def EXAMPLE_MODULE = "example" +final def DEMO_MODULE = "demo" final def VERSION_VARIABLE = "MINECRAFT_VERSION" allprojects { @@ -183,7 +183,7 @@ allprojects { } dependencies { - subprojects.findAll { it.name != TEST_MODULE && it.name != EXAMPLE_MODULE } .each { api project(it.path) } + subprojects.findAll { it.name != TEST_MODULE && it.name != DEMO_MODULE } .each { api project(it.path) } } testCodeCoverageReport { diff --git a/example/build.gradle b/demo/build.gradle similarity index 100% rename from example/build.gradle rename to demo/build.gradle diff --git a/example/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy similarity index 100% rename from example/src/main/groovy/it/angrybear/yagl/YAGL.groovy rename to demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy diff --git a/example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy similarity index 100% rename from example/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy rename to demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy diff --git a/example/src/main/resources/commands/ApplyPotionEffect.groovy b/demo/src/main/resources/commands/ApplyPotionEffect.groovy similarity index 100% rename from example/src/main/resources/commands/ApplyPotionEffect.groovy rename to demo/src/main/resources/commands/ApplyPotionEffect.groovy diff --git a/example/src/main/resources/commands/GetEnchantment.groovy b/demo/src/main/resources/commands/GetEnchantment.groovy similarity index 100% rename from example/src/main/resources/commands/GetEnchantment.groovy rename to demo/src/main/resources/commands/GetEnchantment.groovy diff --git a/example/src/main/resources/commands/PlayEffect.groovy b/demo/src/main/resources/commands/PlayEffect.groovy similarity index 100% rename from example/src/main/resources/commands/PlayEffect.groovy rename to demo/src/main/resources/commands/PlayEffect.groovy diff --git a/example/src/main/resources/commands/PlayParticle.groovy b/demo/src/main/resources/commands/PlayParticle.groovy similarity index 100% rename from example/src/main/resources/commands/PlayParticle.groovy rename to demo/src/main/resources/commands/PlayParticle.groovy diff --git a/example/src/main/resources/commands/PlayYAGLCustomSound.groovy b/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy similarity index 100% rename from example/src/main/resources/commands/PlayYAGLCustomSound.groovy rename to demo/src/main/resources/commands/PlayYAGLCustomSound.groovy diff --git a/example/src/main/resources/commands/PlayYAGLSound.groovy b/demo/src/main/resources/commands/PlayYAGLSound.groovy similarity index 100% rename from example/src/main/resources/commands/PlayYAGLSound.groovy rename to demo/src/main/resources/commands/PlayYAGLSound.groovy diff --git a/example/src/main/resources/plugin.yml b/demo/src/main/resources/plugin.yml similarity index 100% rename from example/src/main/resources/plugin.yml rename to demo/src/main/resources/plugin.yml diff --git a/example/src/test/java/it/angrybear/yagl/YAGLTest.java b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java similarity index 100% rename from example/src/test/java/it/angrybear/yagl/YAGLTest.java rename to demo/src/test/java/it/angrybear/yagl/YAGLTest.java diff --git a/example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java b/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java similarity index 100% rename from example/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java rename to demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java diff --git a/example/src/test/resources/commands/mock.groovy b/demo/src/test/resources/commands/mock.groovy similarity index 100% rename from example/src/test/resources/commands/mock.groovy rename to demo/src/test/resources/commands/mock.groovy diff --git a/example/src/test/resources/number-format-exception-command.groovy b/demo/src/test/resources/number-format-exception-command.groovy similarity index 100% rename from example/src/test/resources/number-format-exception-command.groovy rename to demo/src/test/resources/number-format-exception-command.groovy diff --git a/example/src/test/resources/shell-command.groovy b/demo/src/test/resources/shell-command.groovy similarity index 100% rename from example/src/test/resources/shell-command.groovy rename to demo/src/test/resources/shell-command.groovy diff --git a/settings.gradle b/settings.gradle index 32268302..4da565f9 100644 --- a/settings.gradle +++ b/settings.gradle @@ -43,6 +43,7 @@ include 'gui:gui-serializer' project(':gui:gui-serializer').projectDir = file('gui/serializer') include 'testing' +include 'demo' gradleEnterprise { if (System.getenv("CI") != null) { @@ -53,5 +54,4 @@ gradleEnterprise { } } } -include 'example' From cb9458c3fc8a76b0c083833c965f9d81e187eebb Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 22:23:06 +0200 Subject: [PATCH 062/204] Moved ItemUtils to ItemAdapter --- .../angrybear/yagl/{utils/ItemUtils.java => ItemAdapter.java} | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) rename wrappers/bukkit/src/test/java/it/angrybear/yagl/{utils/ItemUtils.java => ItemAdapter.java} (85%) diff --git a/wrappers/bukkit/src/test/java/it/angrybear/yagl/utils/ItemUtils.java b/wrappers/bukkit/src/test/java/it/angrybear/yagl/ItemAdapter.java similarity index 85% rename from wrappers/bukkit/src/test/java/it/angrybear/yagl/utils/ItemUtils.java rename to wrappers/bukkit/src/test/java/it/angrybear/yagl/ItemAdapter.java index 5d1f739a..b25cba7f 100644 --- a/wrappers/bukkit/src/test/java/it/angrybear/yagl/utils/ItemUtils.java +++ b/wrappers/bukkit/src/test/java/it/angrybear/yagl/ItemAdapter.java @@ -1,4 +1,4 @@ -package it.angrybear.yagl.utils; +package it.angrybear.yagl; import it.angrybear.yagl.items.AbstractItem; import lombok.AccessLevel; @@ -8,7 +8,7 @@ @SuppressWarnings("deprecation") @NoArgsConstructor(access = AccessLevel.PRIVATE) -public final class ItemUtils { +public final class ItemAdapter { public static ItemStack itemToItemStack(AbstractItem item) { return new ItemStack(Material.STONE, 7); From 091af2396bf8073a91132270f8e8e964b855a1c0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 22:30:53 +0200 Subject: [PATCH 063/204] Refactored code --- build.gradle | 62 ++++++++++++++++++++++++++-------------------------- 1 file changed, 31 insertions(+), 31 deletions(-) diff --git a/build.gradle b/build.gradle index bbc85aab..3c6e3cda 100644 --- a/build.gradle +++ b/build.gradle @@ -5,13 +5,13 @@ plugins { id 'io.freefair.lombok' version libs.versions.delombok } +final def TEST_MODULE = 'testing' +final def DEMO_MODULE = 'demo' +final def VERSION_VARIABLE = 'MINECRAFT_VERSION' + group = 'it.angrybear' version = '4.0' -final def TEST_MODULE = "testing" -final def DEMO_MODULE = "demo" -final def VERSION_VARIABLE = "MINECRAFT_VERSION" - allprojects { apply plugin: 'java-library' apply plugin: 'maven-publish' @@ -27,7 +27,7 @@ allprojects { def obsolete_version = libs.versions.spigot.obsolete.get() this.ext.getParentFromProject = { project -> - return new HashMap<>(project.getProperties()).get("parent") + return new HashMap<>(project.getProperties()).get('parent') } this.ext.getProjectGroupId = { @@ -38,7 +38,7 @@ allprojects { tmp = getParentFromProject(tmp) } if (groupId.size() > 0) - groupId = "." + groupId.substring(0, groupId.length() - 1) + groupId = ".${groupId.substring(0, groupId.length() - 1)}" return "${rootProject.group}${groupId}" } @@ -51,18 +51,18 @@ allprojects { repositories { mavenCentral() maven { - name = "spigotmc-repo" + name = 'spigotmc-repo' url = 'https://hub.spigotmc.org/nexus/content/repositories/snapshots/' } maven { url = 'https://oss.sonatype.org/content/repositories/snapshots' } maven { url = 'https://oss.sonatype.org/content/repositories/central' } maven { - name = "JitPack" - url = "https://jitpack.io" + name = 'JitPack' + url = 'https://jitpack.io' } maven { - name = "Fulminazzo repository" - url = "https://repo.fulminazzo.it/releases" + name = 'Fulminazzo repository' + url = 'https://repo.fulminazzo.it/releases' } } @@ -76,46 +76,46 @@ allprojects { def projectName = project.name - if (projectName.contains("serializer")) api(libs.yamlparser) + if (projectName.contains('serializer')) api(libs.yamlparser) - if (projectName.contains("bukkit")) { + if (projectName.contains('bukkit')) { compileOnly libs.spigot testCompileOnly libs.spigot.latest testRuntimeOnly "org.spigotmc:spigot-api:${latest_version}" - String numVersion = latest_version.substring(2, latest_version.indexOf(".", 2)) - def index = numVersion.indexOf("-") + String numVersion = latest_version.substring(2, latest_version.indexOf('.', 2)) + def index = numVersion.indexOf('-') if (index != -1) numVersion = numVersion.substring(0, index) if (Double.valueOf(numVersion) >= 13) testImplementation libs.jbukkit else testImplementation libs.jbukkit.legacy } - if (projectName.contains("legacy")) { + if (projectName.contains('legacy')) { testCompileOnly libs.spigot.legacy testRuntimeOnly "org.spigotmc:spigot-api:${legacy_version}" testImplementation libs.jbukkit.legacy } - if (projectName.contains("obsolete")) { + if (projectName.contains('obsolete')) { testCompileOnly libs.spigot.obsolete testRuntimeOnly "org.spigotmc:spigot-api:${obsolete_version}" testImplementation libs.jbukkit.legacy } - if (projectName.contains("-")) { - def name = projectName.substring(0, projectName.indexOf("-")) - def id = projectName.substring(projectName.indexOf("-") + 1) - if (!projectName.contains("base")) api(project(":${name}:${name}-base")) - if (name != "common" && id != "legacy" && id != "obsolete") + if (projectName.contains('-')) { + def name = projectName.substring(0, projectName.indexOf('-')) + def id = projectName.substring(projectName.indexOf('-') + 1) + if (!projectName.contains('base')) api(project(":${name}:${name}-base")) + if (name != 'common' && id != 'legacy' && id != 'obsolete') api(project(":common:common-${id}")) } testCompileOnly libs.lombok testAnnotationProcessor libs.lombok - if (!project.name.equals(TEST_MODULE)) testImplementation project(":" + TEST_MODULE) + if (!project.name.equals(TEST_MODULE)) testImplementation project(":${TEST_MODULE}") } if (project.name.equals(TEST_MODULE)) return @@ -124,9 +124,9 @@ allprojects { def projectName = project.name if (System.getenv(VERSION_VARIABLE) == null) { - if (projectName.contains("bukkit")) environment VERSION_VARIABLE, latest_version - else if (projectName.contains("legacy")) environment VERSION_VARIABLE, legacy_version - else if (projectName.contains("obsolete")) environment VERSION_VARIABLE, obsolete_version + if (projectName.contains('bukkit')) environment VERSION_VARIABLE, latest_version + else if (projectName.contains('legacy')) environment VERSION_VARIABLE, legacy_version + else if (projectName.contains('obsolete')) environment VERSION_VARIABLE, obsolete_version } def env = System.getenv(VERSION_VARIABLE) @@ -134,14 +134,14 @@ allprojects { useJUnitPlatform() } - tasks.register("testBukkit") { + tasks.register('testBukkit') { final def minecraftVersion = getMinecraftVersion() println "Using Minecraft version ${minecraftVersion}" latest_version = minecraftVersion legacy_version = minecraftVersion obsolete_version = minecraftVersion - subprojects.findAll { it.path.contains("bukkit") }.each {dependsOn "${it.path}:test" } + subprojects.findAll { it.path.contains('bukkit') }.each {dependsOn "${it.path}:test" } } tasks.register('sourcesJar', Jar) { @@ -169,10 +169,10 @@ allprojects { repositories { maven { - url "https://repo.fulminazzo.it/releases" + url 'https://repo.fulminazzo.it/releases' credentials { - username = System.getenv("REPO_USERNAME") - password = System.getenv("REPO_PASSWORD") + username = System.getenv('REPO_USERNAME') + password = System.getenv('REPO_PASSWORD') } authentication { basic(BasicAuthentication) From b0ad2b5e5e78b97278a6dea9dbef5f4697f45ee3 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 22:47:05 +0200 Subject: [PATCH 064/204] Reworked demo dependencies --- build.gradle | 4 ++++ demo/build.gradle | 1 - 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/build.gradle b/build.gradle index 3c6e3cda..ef1330ac 100644 --- a/build.gradle +++ b/build.gradle @@ -116,6 +116,10 @@ allprojects { testAnnotationProcessor libs.lombok if (!project.name.equals(TEST_MODULE)) testImplementation project(":${TEST_MODULE}") + + if (project.name.equals(DEMO_MODULE)) + rootProject.subprojects.findAll { it.name != TEST_MODULE && it.name != DEMO_MODULE } + .each { implementation project(it.path) } } if (project.name.equals(TEST_MODULE)) return diff --git a/demo/build.gradle b/demo/build.gradle index 9f589d90..0e2f17a9 100644 --- a/demo/build.gradle +++ b/demo/build.gradle @@ -6,7 +6,6 @@ plugins { dependencies { implementation libs.groovy - implementation project(":") compileOnly libs.spigot.latest testImplementation libs.spigot.latest From f6ac853b5c739eaab002472b7b5ded7e2ebe1788 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 22:47:33 +0200 Subject: [PATCH 065/204] Added implementation of demo project for coverage reports --- build.gradle | 1 + 1 file changed, 1 insertion(+) diff --git a/build.gradle b/build.gradle index ef1330ac..4d3d4c76 100644 --- a/build.gradle +++ b/build.gradle @@ -188,6 +188,7 @@ allprojects { dependencies { subprojects.findAll { it.name != TEST_MODULE && it.name != DEMO_MODULE } .each { api project(it.path) } + implementation project(":${DEMO_MODULE}") } testCodeCoverageReport { From 4bc6a074c55c407dea85e13fe3069f66e4db7aa5 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 22:51:11 +0200 Subject: [PATCH 066/204] Added test for tab complete of ShellCommand --- .../java/it/angrybear/yagl/commands/ShellCommandTest.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java b/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java index 6d3f1989..1bf30827 100644 --- a/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java +++ b/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java @@ -5,9 +5,11 @@ import org.junit.jupiter.api.Test; import java.io.File; +import java.io.IOException; import java.util.concurrent.atomic.AtomicReference; import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; import static org.mockito.Mockito.*; class ShellCommandTest { @@ -48,4 +50,10 @@ void testNumberFormatExceptionReplacement() { assertEquals(expected, actual); } + @Test + void testTabCompleteShouldNotBeNull() throws IOException { + File file = File.createTempFile("build/resources/test", "file.groovy"); + assertNotNull(new ShellCommand(file).tabComplete(null, null, null)); + } + } \ No newline at end of file From c24ea7b313549867e59946f4e0499f30a7750496 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 22:53:45 +0200 Subject: [PATCH 067/204] Added tests for invalid commands directory --- demo/src/test/java/it/angrybear/yagl/YAGLTest.java | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java index af32ee84..248bf2d1 100644 --- a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -102,6 +102,16 @@ void testUnloadAndUnregisterCommands() { assertNull(commandMap.getCommand("mock"), "Not expected 'mock' command but some was found"); } + @Test + void testInvalidCommandsDirectory() throws IOException { + File file = new File(this.plugin.getDataFolder(), "commands"); + if (file.isFile()) FileUtils.deleteFile(file); + if (file.isDirectory()) FileUtils.deleteFolder(file); + FileUtils.createNewFile(file); + assertDoesNotThrow(() -> this.plugin.loadCommands()); + file.delete(); + } + private void setupPluginManager() { Server server = Bukkit.getServer(); SimpleCommandMap commandMap = new SimpleCommandMap(server); From 43e93669883d63710d53f6bdf0bd8d80608d649d Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:05:10 +0200 Subject: [PATCH 068/204] Added logic interception logic for YAGL plugin --- .../test/java/it/angrybear/yagl/YAGLTest.java | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java index 248bf2d1..e75f8d6f 100644 --- a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -13,21 +13,32 @@ import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; +import java.io.ByteArrayOutputStream; import java.io.File; import java.io.IOException; import java.util.LinkedList; import java.util.List; import java.util.Map; +import java.util.logging.*; import static org.junit.jupiter.api.Assertions.*; import static org.mockito.Mockito.*; class YAGLTest { private YAGL plugin; + private Handler handler; + private ByteArrayOutputStream output; @BeforeEach void setUp() throws IOException { BukkitUtils.setupServer(); + + this.output = new ByteArrayOutputStream(); + this.handler = new StreamHandler(this.output, new SimpleFormatter()); + this.handler.setLevel(Level.ALL); + Logger logger = Logger.getAnonymousLogger(); + logger.addHandler(handler); + this.plugin = mock(YAGL.class); File dataDir = new File("build/resources/test/plugin"); if (dataDir.exists()) FileUtils.deleteFolder(dataDir); @@ -37,6 +48,7 @@ void setUp() throws IOException { doCallRealMethod().when(this.plugin).loadCommands(); doCallRealMethod().when(this.plugin).unloadCommands(); doCallRealMethod().when(this.plugin).saveDefaultCommands(any()); + when(this.plugin.getLogger()).thenReturn(logger); } @Test @@ -118,4 +130,9 @@ private void setupPluginManager() { SimplePluginManager pluginManager = new SimplePluginManager(server, commandMap); when(server.getPluginManager()).thenReturn(pluginManager); } + + private String getOutput() { + this.handler.flush(); + return this.output.toString(); + } } \ No newline at end of file From 2f1fe797cccad6fce78fafd1cda60616b6ff9f50 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:05:13 +0200 Subject: [PATCH 069/204] Added tests for null knownCommands field --- demo/src/test/java/it/angrybear/yagl/YAGLTest.java | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java index e75f8d6f..3cd0ccc4 100644 --- a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -124,6 +124,19 @@ void testInvalidCommandsDirectory() throws IOException { file.delete(); } + @Test + void testNullKnownCommands() { + final String field = "knownCommands"; + + setupPluginManager(); + new Refl<>(Bukkit.getPluginManager()).getFieldRefl("commandMap").setFieldObject(field, null); + + assertDoesNotThrow(() -> this.plugin.unloadCommands()); + + String printOutput = getOutput(); + assertTrue(printOutput.contains(field), String.format("'%s' did not contain '%s'", printOutput, field)); + } + private void setupPluginManager() { Server server = Bukkit.getServer(); SimpleCommandMap commandMap = new SimpleCommandMap(server); From eb378a31d914f30755ebed031b2cceb79a389294 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:05:50 +0200 Subject: [PATCH 070/204] Added tests for null plugin manager --- demo/src/test/java/it/angrybear/yagl/YAGLTest.java | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java index 3cd0ccc4..f839cd90 100644 --- a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -137,6 +137,11 @@ void testNullKnownCommands() { assertTrue(printOutput.contains(field), String.format("'%s' did not contain '%s'", printOutput, field)); } + @Test + void testNullPluginManager() { + assertDoesNotThrow(() -> this.plugin.loadCommands()); + } + private void setupPluginManager() { Server server = Bukkit.getServer(); SimpleCommandMap commandMap = new SimpleCommandMap(server); From d940661595a5db54c5f3f95651e2b5c2a9daf24c Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:09:18 +0200 Subject: [PATCH 071/204] Added mock parameters --- .../test/java/it/angrybear/yagl/commands/ShellCommandTest.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java b/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java index 1bf30827..719568c3 100644 --- a/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java +++ b/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java @@ -53,7 +53,8 @@ void testNumberFormatExceptionReplacement() { @Test void testTabCompleteShouldNotBeNull() throws IOException { File file = File.createTempFile("build/resources/test", "file.groovy"); - assertNotNull(new ShellCommand(file).tabComplete(null, null, null)); + assertNotNull(new ShellCommand(file).tabComplete(mock(CommandSender.class), + "command", new String[0])); } } \ No newline at end of file From 0f8d6cfe909a11a1c4c5895612b1f34f7951edc7 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:14:00 +0200 Subject: [PATCH 072/204] Added tests for onEnable and onDisable to invoke load and unload commands respectively --- .../test/java/it/angrybear/yagl/YAGLTest.java | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java index f839cd90..d9ac4a2f 100644 --- a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -16,6 +16,7 @@ import java.io.ByteArrayOutputStream; import java.io.File; import java.io.IOException; +import java.util.ArrayList; import java.util.LinkedList; import java.util.List; import java.util.Map; @@ -51,6 +52,24 @@ void setUp() throws IOException { when(this.plugin.getLogger()).thenReturn(logger); } + @Test + void testOnEnableShouldCallLoadCommands() { + YAGL plugin = mock(YAGL.class); + when(plugin.getLogger()).thenReturn(Logger.getAnonymousLogger()); + new Refl<>(plugin).setFieldObject("commands", new ArrayList<>()); + doCallRealMethod().when(plugin).onEnable(); + plugin.onEnable(); + verify(plugin, atLeastOnce()).loadCommands(); + } + + @Test + void testOnDisableShouldCallUnloadCommands() { + YAGL plugin = mock(YAGL.class); + doCallRealMethod().when(plugin).onDisable(); + plugin.onDisable(); + verify(plugin, atLeastOnce()).unloadCommands(); + } + @Test void testLoadCommands() { this.plugin.loadCommands(); From 15ea46d028e342942971492645d32f143794569a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:20:43 +0200 Subject: [PATCH 073/204] Added check for pre-existence of file in which to write resource --- demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 1 + 1 file changed, 1 insertion(+) diff --git a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 09444807..7f422884 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -86,6 +86,7 @@ class YAGL extends JavaPlugin { private void writeResourceToFile(final @NotNull File dir, final @NotNull String fileName, final @NotNull resourceDir) { def file = new File(dir, fileName) + if (file.exists()) FileUtils.deleteFile(file) FileUtils.createNewFile(file) def input = getClass().getResourceAsStream("${resourceDir}/${fileName}") def output = new FileOutputStream(file) From 8c1aa30bbe8a03641ea49c7b7f8d6e740fc4de7f Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:21:06 +0200 Subject: [PATCH 074/204] Added tests for jarEntries --- .../test/java/it/angrybear/yagl/YAGLTest.java | 22 +++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) diff --git a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java index d9ac4a2f..6fcd9a84 100644 --- a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -2,6 +2,7 @@ import it.angrybear.yagl.commands.ShellCommand; import it.fulminazzo.fulmicollection.objects.Refl; +import it.fulminazzo.fulmicollection.utils.JarUtils; import it.fulminazzo.jbukkit.BukkitUtils; import it.fulminazzo.yamlparser.utils.FileUtils; import org.bukkit.Bukkit; @@ -12,14 +13,12 @@ import org.bukkit.plugin.SimplePluginManager; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; +import org.mockito.MockedStatic; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.IOException; -import java.util.ArrayList; -import java.util.LinkedList; -import java.util.List; -import java.util.Map; +import java.util.*; import java.util.logging.*; import static org.junit.jupiter.api.Assertions.*; @@ -161,6 +160,21 @@ void testNullPluginManager() { assertDoesNotThrow(() -> this.plugin.loadCommands()); } + @Test + void simulateJarEntries() { + setupPluginManager(); + List entries = Arrays.asList("ignored", "also-ignored", "commands", "commands/", "commands/mock.groovy"); + try (MockedStatic ignored = mockStatic(JarUtils.class)) { + when(JarUtils.getEntries((Class) any(), anyString())).thenAnswer(a -> entries.iterator()); + + this.plugin.loadCommands(); + + List commands = new Refl<>(this.plugin).getFieldObject("commands"); + assertNotNull(commands); + assertEquals(1, commands.size(), "Commands size did not match expected"); + } + } + private void setupPluginManager() { Server server = Bukkit.getServer(); SimpleCommandMap commandMap = new SimpleCommandMap(server); From cb4d7e2fe864ed62044cc39c5a9beb52c9d4e09d Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:28:47 +0200 Subject: [PATCH 075/204] Refactored code for JaCoCo coverage report --- demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 7f422884..58437d2c 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -45,23 +45,21 @@ class YAGL extends JavaPlugin { * Unloads all the commands loaded in {@link #commands}. */ void unloadCommands() { - commandMap().ifPresent { map -> + commandMap().ifPresent(map -> { Map commands = new Refl<>(map).getFieldObject('knownCommands') if (commands == null) getLogger().warning('Could not find \'knownCommands\' field in CommandMap') else commands.keySet().collect().each { key -> Command value = commands.get(key) if (this.commands.contains(value)) commands.remove(key, value) } - } + }) } private static Optional commandMap() { def pluginManager = Bukkit.getPluginManager() - if (pluginManager == null) Optional.empty() - else { - def refl = new Refl<>(pluginManager) - Optional.ofNullable(refl.getFieldObject('commandMap')) - } + // Terrible line, but necessary for JaCoCo coverage report to 100% + pluginManager == null ? Optional.empty() : Optional.ofNullable((CommandMap) new Refl<>(pluginManager) + .getFieldObject('commandMap')) } /** From 1c5edbbef5db39e68cc6bf845a2aa1f8d64317b0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:40:34 +0200 Subject: [PATCH 076/204] Created GiveItem command --- .../main/resources/commands/GiveItem.groovy | 36 +++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 demo/src/main/resources/commands/GiveItem.groovy diff --git a/demo/src/main/resources/commands/GiveItem.groovy b/demo/src/main/resources/commands/GiveItem.groovy new file mode 100644 index 00000000..bdd5bf78 --- /dev/null +++ b/demo/src/main/resources/commands/GiveItem.groovy @@ -0,0 +1,36 @@ +import it.angrybear.yagl.items.BukkitItem +import it.angrybear.yagl.items.Item +import it.angrybear.yagl.items.fields.ItemFlag +import it.angrybear.yagl.wrappers.Enchantment +import it.angrybear.yagl.wrappers.WrapperParser +import org.bukkit.entity.Player + +def run = { sender, label, args -> + if (sender instanceof Player) + try { + Item item = Item.newItem(args[0]) + try { + item.setAmount(Integer.valueOf(args[1])) + .setDurability(Integer.valueOf(args[2])) + .setDisplayName(args[3]) + .setLore(args[4].split(";")) + .addEnchantments(Arrays.stream(args[5].split(";")) + .map(a -> WrapperParser.parseWrapperFromString(a, Enchantment)) + .toArray(Enchantment[]::new)) + .addItemFlags(Arrays.stream(args[6].split(";")) + .map(a -> ItemFlag.valueOf(a.toUpperCase())) + .toArray(ItemFlag[]::new)) + .setUnbreakable(Boolean.valueOf(args[7])) + .setCustomModelData(Integer.valueOf(args[8])) + } catch (IndexOutOfBoundsException ignored) { + + } + sender.getInventory().addItem(item.copy(BukkitItem).create()) + } catch (NumberFormatException ignored) { + + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /item ') + sender.sendMessage('At least material is required!') + } + else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From 4a8119b612faca71fa62fc3d6ece03db6b747d9b Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:51:11 +0200 Subject: [PATCH 077/204] Created CreateRecipe command with shapeless method --- .../resources/commands/CreateRecipe.groovy | 35 +++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 demo/src/main/resources/commands/CreateRecipe.groovy diff --git a/demo/src/main/resources/commands/CreateRecipe.groovy b/demo/src/main/resources/commands/CreateRecipe.groovy new file mode 100644 index 00000000..b91bfb0d --- /dev/null +++ b/demo/src/main/resources/commands/CreateRecipe.groovy @@ -0,0 +1,35 @@ +import it.angrybear.yagl.items.BukkitItem +import it.angrybear.yagl.items.Item +import it.angrybear.yagl.items.recipes.ShapelessRecipe +import org.bukkit.entity.Player + +def shapeless(sender, label, args, output, name) { + try { + if (args.length == 0) throw new IndexOutOfBoundsException() + BukkitItem.newRecipeItem(output) + .addRecipes(new ShapelessRecipe(name) + .addIngredients(Arrays.stream(args) + .map(Item::newItem) + .toArray(Item[]::new))) + .registerRecipes() + sender.sendMessage('Ok') + } catch (NumberFormatException ignored) { + + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /createrecipe shapeless ') + } +} + +def run = { sender, label, args -> + if (sender instanceof Player) + try { + "${args[2].toLowerCase()}"(sender, label, Arrays.copyOfRange(args, 3, args.length), args[1], args[0]) + } catch (NumberFormatException ignored) { + + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /createrecipe ') + } catch (Exception e) { + sender.sendMessage(e.getMessage()) + } + else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From a342fb09b7c06429c0c0aa2337dd76c41a3c11e1 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Mon, 15 Apr 2024 23:53:14 +0200 Subject: [PATCH 078/204] Added furnace method --- .../main/resources/commands/CreateRecipe.groovy | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/demo/src/main/resources/commands/CreateRecipe.groovy b/demo/src/main/resources/commands/CreateRecipe.groovy index b91bfb0d..a2f7628d 100644 --- a/demo/src/main/resources/commands/CreateRecipe.groovy +++ b/demo/src/main/resources/commands/CreateRecipe.groovy @@ -1,5 +1,6 @@ import it.angrybear.yagl.items.BukkitItem import it.angrybear.yagl.items.Item +import it.angrybear.yagl.items.recipes.FurnaceRecipe import it.angrybear.yagl.items.recipes.ShapelessRecipe import org.bukkit.entity.Player @@ -20,6 +21,22 @@ def shapeless(sender, label, args, output, name) { } } +def furnace(sender, label, args, output, name) { + try { + BukkitItem.newRecipeItem(output) + .addRecipes(new FurnaceRecipe(name) + .setIngredient(Item.newItem(args[0])) + .setCookingTime(Double.valueOf(args[1])) + .setExperience(Float.valueOf(args[2]))) + .registerRecipes() + sender.sendMessage('Ok') + } catch (NumberFormatException ignored) { + + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /createrecipe furnace ') + } +} + def run = { sender, label, args -> if (sender instanceof Player) try { From 517793c89018edc43d0638d1161e466d3588e581 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 00:22:58 +0200 Subject: [PATCH 079/204] Added shaped method --- .../resources/commands/CreateRecipe.groovy | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/demo/src/main/resources/commands/CreateRecipe.groovy b/demo/src/main/resources/commands/CreateRecipe.groovy index a2f7628d..274656b6 100644 --- a/demo/src/main/resources/commands/CreateRecipe.groovy +++ b/demo/src/main/resources/commands/CreateRecipe.groovy @@ -1,9 +1,27 @@ import it.angrybear.yagl.items.BukkitItem import it.angrybear.yagl.items.Item import it.angrybear.yagl.items.recipes.FurnaceRecipe +import it.angrybear.yagl.items.recipes.ShapedRecipe import it.angrybear.yagl.items.recipes.ShapelessRecipe import org.bukkit.entity.Player +def shaped(sender, label, args, output, name) { + try { + def rows = Integer.valueOf(args[0]) + def columns = Integer.valueOf(args[1]) + def recipe = new ShapedRecipe(name).setShape(rows, columns) + if (args.length < 2) throw new IndexOutOfBoundsException() + for (int i = 2; i < args.length; i += 1) + recipe.setIngredient(i - 2, Item.newItem(args[i])) + BukkitItem.newRecipeItem(output).addRecipes(recipe).registerRecipes() + sender.sendMessage('Ok') + } catch (NumberFormatException ignored) { + + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /createrecipe shaped ') + } +} + def shapeless(sender, label, args, output, name) { try { if (args.length == 0) throw new IndexOutOfBoundsException() From 1e90ecfd228e2ffcaee228a10978cfedaed19495 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 00:24:17 +0200 Subject: [PATCH 080/204] Registered persistent listener --- demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 2 ++ 1 file changed, 2 insertions(+) diff --git a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 58437d2c..0c8912db 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -2,6 +2,7 @@ package it.angrybear.yagl import groovy.transform.CompileStatic import it.angrybear.yagl.commands.ShellCommand +import it.angrybear.yagl.listeners.PersistentListener import it.fulminazzo.fulmicollection.objects.Refl import it.fulminazzo.fulmicollection.utils.JarUtils import it.fulminazzo.yamlparser.utils.FileUtils @@ -18,6 +19,7 @@ class YAGL extends JavaPlugin { @Override void onEnable() { loadCommands() + Bukkit.getPluginManager().registerEvents(new PersistentListener(), this) getLogger().info("Loaded ${commands.size()} commands") } From a0071664a1a8150cf1752ec4786a34e089d3df18 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 00:25:49 +0200 Subject: [PATCH 081/204] Updated usage --- demo/src/main/resources/commands/GiveItem.groovy | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/demo/src/main/resources/commands/GiveItem.groovy b/demo/src/main/resources/commands/GiveItem.groovy index bdd5bf78..4314a396 100644 --- a/demo/src/main/resources/commands/GiveItem.groovy +++ b/demo/src/main/resources/commands/GiveItem.groovy @@ -29,7 +29,7 @@ def run = { sender, label, args -> } catch (NumberFormatException ignored) { } catch (IndexOutOfBoundsException ignored) { - sender.sendMessage('Usage: /item ') + sender.sendMessage('Usage: /giveitem ') sender.sendMessage('At least material is required!') } else sender.sendMessage('Console cannot execute this command!') From 29cf389ad33f8be3e48bdea56b836ff610b1e2e5 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 00:27:14 +0200 Subject: [PATCH 082/204] Created givepersistentitem command --- .../commands/GivePersistentItem.groovy | 41 +++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 demo/src/main/resources/commands/GivePersistentItem.groovy diff --git a/demo/src/main/resources/commands/GivePersistentItem.groovy b/demo/src/main/resources/commands/GivePersistentItem.groovy new file mode 100644 index 00000000..aa3359f6 --- /dev/null +++ b/demo/src/main/resources/commands/GivePersistentItem.groovy @@ -0,0 +1,41 @@ +import it.angrybear.yagl.items.BukkitItem +import it.angrybear.yagl.items.DeathAction +import it.angrybear.yagl.items.Item +import it.angrybear.yagl.items.Mobility +import it.angrybear.yagl.items.PersistentItem +import it.angrybear.yagl.items.fields.ItemFlag +import it.angrybear.yagl.wrappers.Enchantment +import it.angrybear.yagl.wrappers.WrapperParser +import org.bukkit.entity.Player + +def run = { sender, label, args -> + if (sender instanceof Player) + try { + DeathAction action = DeathAction.valueOf(args[0].toUpperCase()) + Mobility mobility = Mobility.valueOf(args[1].toUpperCase()) + PersistentItem item = PersistentItem.newItem(args[2]).setDeathAction(action).setMobility(mobility) + try { + item.setAmount(Integer.valueOf(args[3])) + .setDurability(Integer.valueOf(args[4])) + .setDisplayName(args[5]) + .setLore(args[6].split(";")) + .addEnchantments(Arrays.stream(args[7].split(";")) + .map(a -> WrapperParser.parseWrapperFromString(a, Enchantment)) + .toArray(Enchantment[]::new)) + .addItemFlags(Arrays.stream(args[8].split(";")) + .map(a -> ItemFlag.valueOf(a.toUpperCase())) + .toArray(ItemFlag[]::new)) + .setUnbreakable(Boolean.valueOf(args[9])) + .setCustomModelData(Integer.valueOf(args[10])) + } catch (IndexOutOfBoundsException ignored) { + + } + sender.getInventory().addItem(item.copy(BukkitItem).create()) + } catch (NumberFormatException ignored) { + + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage('Usage: /givepersistentitem ') + sender.sendMessage('At least death-action, mobility and material are required!') + } + else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From 6e45bfd34b43c671ac47b214cb5ff01f41932a86 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 00:44:44 +0200 Subject: [PATCH 083/204] Fixed PersistentListener not checking for move to other inventory with valid slot --- .../it/angrybear/yagl/listeners/PersistentListener.java | 6 ++++-- .../it/angrybear/yagl/listeners/PersistentListenerTest.java | 1 + 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/item/bukkit/src/main/java/it/angrybear/yagl/listeners/PersistentListener.java b/item/bukkit/src/main/java/it/angrybear/yagl/listeners/PersistentListener.java index b68a9988..046265e1 100644 --- a/item/bukkit/src/main/java/it/angrybear/yagl/listeners/PersistentListener.java +++ b/item/bukkit/src/main/java/it/angrybear/yagl/listeners/PersistentListener.java @@ -12,6 +12,7 @@ import org.bukkit.event.block.BlockPlaceEvent; import org.bukkit.event.entity.PlayerDeathEvent; import org.bukkit.event.inventory.ClickType; +import org.bukkit.event.inventory.InventoryAction; import org.bukkit.event.inventory.InventoryClickEvent; import org.bukkit.event.inventory.InventoryDragEvent; import org.bukkit.event.player.PlayerDropItemEvent; @@ -129,7 +130,7 @@ protected void on(@NotNull InventoryClickEvent event) { ItemStack itemStack = event.getCurrentItem(); Consumer ifPresent = clickConsumer(event, player); - // Check the current item and the cursor; + // Check the current item and the cursor. if (!clickPersistentItem(player, type, ifPresent, itemStack, event.getCursor()) && type.equals(ClickType.NUMBER_KEY)) { // Check if a number has been used from the keyboard to move the item. itemStack = player.getInventory().getItem(event.getHotbarButton()); @@ -174,7 +175,8 @@ protected void on(@NotNull InventoryDragEvent event) { return e -> { Inventory open = player.getOpenInventory().getTopInventory(); int rawSlot = event.getRawSlot(); - if (e.getMobility() != Mobility.INTERNAL || rawSlot < open.getSize()) cancelled(event).accept(e); + if (e.getMobility() != Mobility.INTERNAL || (rawSlot < open.getSize() || event.getAction().equals(InventoryAction.MOVE_TO_OTHER_INVENTORY))) + cancelled(event).accept(e); }; } diff --git a/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java b/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java index 160f1f6b..486ed7c6 100644 --- a/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java +++ b/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java @@ -244,6 +244,7 @@ private InventoryClickEvent[] inventoryClickEvents() { new InventoryClickEvent(view, InventoryType.SlotType.CONTAINER, 0, ClickType.LEFT, InventoryAction.CLONE_STACK), new InventoryClickEvent(view, InventoryType.SlotType.CONTAINER, 2, ClickType.LEFT, InventoryAction.CLONE_STACK), new InventoryClickEvent(view, InventoryType.SlotType.CONTAINER, 3, ClickType.NUMBER_KEY, InventoryAction.CLONE_STACK, 0), + new InventoryClickEvent(view, InventoryType.SlotType.CONTAINER, 9, ClickType.SHIFT_LEFT, InventoryAction.MOVE_TO_OTHER_INVENTORY), }; } From 47185d20ac47814c0e1a6be974d6a4378de0daea Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 00:44:54 +0200 Subject: [PATCH 084/204] Fixed PersistentListenerTest convertSlot method --- .../angrybear/yagl/listeners/PersistentListenerTest.java | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java b/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java index 486ed7c6..f9164af2 100644 --- a/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java +++ b/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java @@ -214,7 +214,12 @@ private static InventoryView getInventoryView(Player player, Inventory inventory when(view.getPlayer()).thenReturn(player); when(view.getItem(any(int.class))).thenCallRealMethod(); when(view.getCursor()).thenCallRealMethod(); - when(view.convertSlot(any(int.class))).thenCallRealMethod(); + when(view.convertSlot(any(int.class))).thenAnswer(a -> { + int slot = a.getArgument(0); + int size = inventory.getSize(); + if (slot >= size) slot -= size; + return slot; + }); when(view.getInventory(any(int.class))).thenAnswer(a -> { int slot = a.getArgument(0); if (slot < inventory.getSize()) return inventory; From d77a4034069328e3a50d68d1bad34f73f4921dce Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 00:45:43 +0200 Subject: [PATCH 085/204] Fixed Null Pointer Exception --- demo/src/test/java/it/angrybear/yagl/YAGLTest.java | 1 + 1 file changed, 1 insertion(+) diff --git a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java index 6fcd9a84..b965820c 100644 --- a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -53,6 +53,7 @@ void setUp() throws IOException { @Test void testOnEnableShouldCallLoadCommands() { + setupPluginManager(); YAGL plugin = mock(YAGL.class); when(plugin.getLogger()).thenReturn(Logger.getAnonymousLogger()); new Refl<>(plugin).setFieldObject("commands", new ArrayList<>()); From cff130007a5d36934115e2caf44bc25dc2cfe601 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 00:46:41 +0200 Subject: [PATCH 086/204] Fixed Null Pointer Exception --- demo/src/test/java/it/angrybear/yagl/YAGLTest.java | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java index b965820c..30bc9b06 100644 --- a/demo/src/test/java/it/angrybear/yagl/YAGLTest.java +++ b/demo/src/test/java/it/angrybear/yagl/YAGLTest.java @@ -10,6 +10,7 @@ import org.bukkit.command.Command; import org.bukkit.command.CommandMap; import org.bukkit.command.SimpleCommandMap; +import org.bukkit.plugin.PluginManager; import org.bukkit.plugin.SimplePluginManager; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; @@ -53,7 +54,9 @@ void setUp() throws IOException { @Test void testOnEnableShouldCallLoadCommands() { - setupPluginManager(); + Server server = mock(Server.class); + when(server.getPluginManager()).thenReturn(mock(PluginManager.class)); + new Refl<>(Bukkit.class).setFieldObject("server", server); YAGL plugin = mock(YAGL.class); when(plugin.getLogger()).thenReturn(Logger.getAnonymousLogger()); new Refl<>(plugin).setFieldObject("commands", new ArrayList<>()); From 2ce5f8044526936d9a8cd1ee6297b471369098e0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 12:55:01 +0200 Subject: [PATCH 087/204] Created opengui command --- .../main/resources/commands/OpenGUI.groovy | 42 +++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 demo/src/main/resources/commands/OpenGUI.groovy diff --git a/demo/src/main/resources/commands/OpenGUI.groovy b/demo/src/main/resources/commands/OpenGUI.groovy new file mode 100644 index 00000000..1113565b --- /dev/null +++ b/demo/src/main/resources/commands/OpenGUI.groovy @@ -0,0 +1,42 @@ +import it.angrybear.yagl.GUIManager +import it.angrybear.yagl.guis.GUI +import it.angrybear.yagl.items.Item +import it.angrybear.yagl.items.fields.ItemFlag +import it.angrybear.yagl.utils.EnumUtils +import org.bukkit.entity.Player + +def run = { sender, label, args -> + if (sender instanceof Player) + try { + def columns = 9 + def border = Item.newItem("black_stained_glass_pane").setDisplayName(" ") + GUI gui = GUI.newGUI(27) + for (int i = 0; i < columns; i += 1) { + gui.setContents(i, border) + gui.setContents(gui.size() - i - 1, border) + } + for (int i = 0; i < gui.size(); i += columns) { + gui.setContents(i, border) + gui.setContents(gui.size() - i - 1, border) + } + def middle = (int) (gui.size() / 2) + gui.setContents(middle, Item.newItem("gold_block").setDisplayName("This is a demo GUI!") + .addEnchantment("unbreaking", 1) + .addItemFlags(ItemFlag.HIDE_ENCHANTS)) + .setContents(middle - 1, Item.newItem("diamond_sword") + .setDisplayName("Pick me!") + .addEnchantment("sharpness", 2)) + .setContents(middle + 1, Item.newItem("diamond_pickaxe") + .setDisplayName("Can't pick me...") + .addEnchantment("efficiency", 10)) + .setMovable(middle - 1, true) + .setTitle("Demo GUI") + .open(GUIManager.getViewer(sender)) + } catch (NumberFormatException ignored) { + + } catch (Exception e) { + e.printStackTrace() + sender.sendMessage(e.getMessage()) + } + else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From a9b6bbf0727bea55ef4e8447b5cb23cc561af3a4 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 13:00:38 +0200 Subject: [PATCH 088/204] Added option for type and size to be specified in opengui command --- demo/src/main/resources/commands/OpenGUI.groovy | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/demo/src/main/resources/commands/OpenGUI.groovy b/demo/src/main/resources/commands/OpenGUI.groovy index 1113565b..656be377 100644 --- a/demo/src/main/resources/commands/OpenGUI.groovy +++ b/demo/src/main/resources/commands/OpenGUI.groovy @@ -1,5 +1,6 @@ import it.angrybear.yagl.GUIManager import it.angrybear.yagl.guis.GUI +import it.angrybear.yagl.guis.GUIType import it.angrybear.yagl.items.Item import it.angrybear.yagl.items.fields.ItemFlag import it.angrybear.yagl.utils.EnumUtils @@ -10,7 +11,15 @@ def run = { sender, label, args -> try { def columns = 9 def border = Item.newItem("black_stained_glass_pane").setDisplayName(" ") - GUI gui = GUI.newGUI(27) + GUI gui + try { + gui = GUI.newGUI(EnumUtils.valueOf(GUIType, args[0])) + } catch (IllegalArgumentException ignored) { + gui = GUI.newResizableGUI(Integer.valueOf(args[0])) + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage("Usage: /opengui ") + return + } for (int i = 0; i < columns; i += 1) { gui.setContents(i, border) gui.setContents(gui.size() - i - 1, border) From 4e8224d169de9d9e39a327d7c3654a86502a95ec Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 13:00:44 +0200 Subject: [PATCH 089/204] Fixed Metadatable not ignoring Enums --- gui/base/src/main/java/it/angrybear/yagl/Metadatable.java | 1 + 1 file changed, 1 insertion(+) diff --git a/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java b/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java index f6385305..aa5aa65f 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java +++ b/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java @@ -123,6 +123,7 @@ default boolean hasVariable(final @NotNull String name) { @SuppressWarnings("unchecked") default T apply(final T object) { if (object == null) return null; + else if (object.getClass().isEnum()) return object; else if (object instanceof String) return (T) apply((String) object); else if (object instanceof Collection) return (T) apply((Collection) object); else if (object instanceof Map) return (T) apply((Map) object); From 7ac3ecbff6863f11abc742d6934b319f9f59f85d Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 13:05:13 +0200 Subject: [PATCH 090/204] Fixed index out of bounds exceptions --- .../main/resources/commands/OpenGUI.groovy | 22 +++++++++---------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/demo/src/main/resources/commands/OpenGUI.groovy b/demo/src/main/resources/commands/OpenGUI.groovy index 656be377..e59b0afa 100644 --- a/demo/src/main/resources/commands/OpenGUI.groovy +++ b/demo/src/main/resources/commands/OpenGUI.groovy @@ -20,7 +20,7 @@ def run = { sender, label, args -> sender.sendMessage("Usage: /opengui ") return } - for (int i = 0; i < columns; i += 1) { + for (int i = 0; i < Math.min(gui.size(), columns); i += 1) { gui.setContents(i, border) gui.setContents(gui.size() - i - 1, border) } @@ -32,19 +32,19 @@ def run = { sender, label, args -> gui.setContents(middle, Item.newItem("gold_block").setDisplayName("This is a demo GUI!") .addEnchantment("unbreaking", 1) .addItemFlags(ItemFlag.HIDE_ENCHANTS)) - .setContents(middle - 1, Item.newItem("diamond_sword") - .setDisplayName("Pick me!") - .addEnchantment("sharpness", 2)) - .setContents(middle + 1, Item.newItem("diamond_pickaxe") - .setDisplayName("Can't pick me...") - .addEnchantment("efficiency", 10)) - .setMovable(middle - 1, true) - .setTitle("Demo GUI") - .open(GUIManager.getViewer(sender)) + if (middle - 1 >= 0) + gui.setContents(middle - 1, Item.newItem("diamond_sword") + .setDisplayName("Pick me!") + .addEnchantment("sharpness", 2)) + .setMovable(middle - 1, true) + if (middle + 1 < gui.size()) + gui.setContents(middle + 1, Item.newItem("diamond_pickaxe") + .setDisplayName("Can't pick me...") + .addEnchantment("efficiency", 10)) + gui.setTitle("Demo GUI").open(GUIManager.getViewer(sender)) } catch (NumberFormatException ignored) { } catch (Exception e) { - e.printStackTrace() sender.sendMessage(e.getMessage()) } else sender.sendMessage('Console cannot execute this command!') From 2ce2f4debcbc4bc35002f67174350676337312dc Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 13:34:20 +0200 Subject: [PATCH 091/204] Added GUIAdapter#closeGUI method --- .../java/it/angrybear/yagl/GUIAdapter.java | 18 ++++++++++++++++++ .../java/it/angrybear/yagl/GUIManager.java | 5 +---- 2 files changed, 19 insertions(+), 4 deletions(-) diff --git a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java index 470e1f19..4ac24469 100644 --- a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java +++ b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java @@ -59,6 +59,24 @@ public static void openGUI(final @NotNull GUI gui, @NotNull Viewer viewer) { player.openInventory(inventory); } + /** + * Closes the currently open {@link GUI} for the specified {@link Viewer}, if present. + * + * @param viewer the viewer + */ + public static void closeGUI(final @NotNull Viewer viewer) { + final UUID uuid = viewer.getUniqueId(); + final Player player = Bukkit.getPlayer(uuid); + if (player == null) throw new PlayerOfflineException(viewer.getName()); + final Refl reflViewer = new Refl<>(viewer); + // Save previous GUI, if present + GUIManager.getOpenGUIViewer(uuid).ifPresent((v, g) -> { + reflViewer.setFieldObject("previousGUI", g).setFieldObject("openGUI", null); + g.closeGUIAction().ifPresent(a -> a.execute(v, g)); + player.closeInventory(); + }); + } + /** * Converts the given {@link GUI} to a {@link Inventory}. * diff --git a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java index 73c3957b..c8da6980 100644 --- a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java +++ b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java @@ -8,7 +8,6 @@ import it.fulminazzo.fulmicollection.utils.ReflectionUtils; import org.bukkit.Bukkit; import org.bukkit.entity.HumanEntity; -import org.bukkit.entity.Player; import org.bukkit.event.EventHandler; import org.bukkit.event.Listener; import org.bukkit.event.inventory.InventoryClickEvent; @@ -69,9 +68,7 @@ void on(final @NotNull InventoryDragEvent event) { @EventHandler void on(final @NotNull InventoryCloseEvent event) { - Player player = (Player) event.getPlayer(); - getOpenGUIViewer(player).ifPresent((v, g) -> - g.closeGUIAction().ifPresent(a -> a.execute(v, g))); + GUIAdapter.closeGUI(getViewer(event.getPlayer())); } @EventHandler From 8e9a3231b93d083e3c8c3ef39ab3fc12cdb18ef6 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 16:19:58 +0200 Subject: [PATCH 092/204] Added Viewer#sendMessage method --- .../it/angrybear/yagl/viewers/Viewer.java | 19 +++++++++++++++++++ .../angrybear/yagl/viewers/BukkitViewer.java | 6 ++++++ 2 files changed, 25 insertions(+) diff --git a/gui/base/src/main/java/it/angrybear/yagl/viewers/Viewer.java b/gui/base/src/main/java/it/angrybear/yagl/viewers/Viewer.java index af91ebb0..be869bee 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/viewers/Viewer.java +++ b/gui/base/src/main/java/it/angrybear/yagl/viewers/Viewer.java @@ -12,9 +12,21 @@ */ @Getter public abstract class Viewer { + /** + * The Unique id. + */ protected final UUID uniqueId; + /** + * The Name. + */ protected final String name; + /** + * The Previous gui. + */ protected GUI previousGUI; + /** + * The Open gui. + */ protected GUI openGUI; /** @@ -44,6 +56,13 @@ public boolean hasOpenGUI() { */ public abstract void playSound(final @NotNull Sound sound); + /** + * Sends the given message to the player. + * + * @param message the message + */ + public abstract void sendMessage(final @NotNull String message); + /** * Execute command. * diff --git a/gui/bukkit/src/main/java/it/angrybear/yagl/viewers/BukkitViewer.java b/gui/bukkit/src/main/java/it/angrybear/yagl/viewers/BukkitViewer.java index 8ad5290e..3e2eae9e 100644 --- a/gui/bukkit/src/main/java/it/angrybear/yagl/viewers/BukkitViewer.java +++ b/gui/bukkit/src/main/java/it/angrybear/yagl/viewers/BukkitViewer.java @@ -32,6 +32,12 @@ public void playSound(@NotNull Sound sound) { WrappersAdapter.playCustomSound(player, sound); } + @Override + public void sendMessage(@NotNull String message) { + Player player = getPlayer().orElseThrow(() -> new PlayerOfflineException(this.name)); + player.sendMessage(message); + } + @Override public void executeCommand(final @NotNull String command) { Player player = getPlayer().orElseThrow(() -> new PlayerOfflineException(this.name)); From 9ef94de2851398256baade163ec88ef842feaf4b Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 16:24:51 +0200 Subject: [PATCH 093/204] Increased openGUI test efficacy --- demo/src/main/resources/commands/OpenGUI.groovy | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/demo/src/main/resources/commands/OpenGUI.groovy b/demo/src/main/resources/commands/OpenGUI.groovy index e59b0afa..b3979163 100644 --- a/demo/src/main/resources/commands/OpenGUI.groovy +++ b/demo/src/main/resources/commands/OpenGUI.groovy @@ -1,4 +1,5 @@ import it.angrybear.yagl.GUIManager +import it.angrybear.yagl.contents.ItemGUIContent import it.angrybear.yagl.guis.GUI import it.angrybear.yagl.guis.GUIType import it.angrybear.yagl.items.Item @@ -29,7 +30,7 @@ def run = { sender, label, args -> gui.setContents(gui.size() - i - 1, border) } def middle = (int) (gui.size() / 2) - gui.setContents(middle, Item.newItem("gold_block").setDisplayName("This is a demo GUI!") + gui.setContents(middle, Item.newItem("gold_block").setDisplayName("This is a GUI!") .addEnchantment("unbreaking", 1) .addItemFlags(ItemFlag.HIDE_ENCHANTS)) if (middle - 1 >= 0) @@ -38,10 +39,16 @@ def run = { sender, label, args -> .addEnchantment("sharpness", 2)) .setMovable(middle - 1, true) if (middle + 1 < gui.size()) - gui.setContents(middle + 1, Item.newItem("diamond_pickaxe") + gui.setContents(middle + 1, ItemGUIContent.newInstance("diamond_pickaxe") .setDisplayName("Can't pick me...") - .addEnchantment("efficiency", 10)) - gui.setTitle("Demo GUI").open(GUIManager.getViewer(sender)) + .addEnchantment("efficiency", 10) + .onClickItem((v, g, c) -> v.sendMessage('You cannot pick this item!'))) + gui.setTitle(" GUI") + .onClickOutside((v, g) -> v.sendMessage('Please only click inside me!')) + .onOpenGUI((v, g) -> v.sendMessage('Opening the GUI... voila')) + .onCloseGUI((v, g) -> v.sendMessage('Goodbye!')) + .setVariable("name", "Demo") + .open(GUIManager.getViewer(sender)) } catch (NumberFormatException ignored) { } catch (Exception e) { From c0fb37476d870f7ab2fa0bcab05540f79c16e955 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 16:31:53 +0200 Subject: [PATCH 094/204] Fixed GUI not applying variables to itself --- gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java index 1ac708b4..d18ab381 100644 --- a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java +++ b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java @@ -76,7 +76,7 @@ public static void openGUI(final @NotNull GUI gui, @NotNull player.closeInventory(); }); // Set new GUI - reflViewer.setFieldObject("openGUI", gui); + reflViewer.setFieldObject("openGUI", gui.apply(gui)); // Open inventory Inventory inventory = guiToInventory(gui); for (int i = 0; i < gui.size(); i++) { From fda04e3d154f2773d071feb68da26bd0d167d3de Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 16:32:47 +0200 Subject: [PATCH 095/204] Fixed MockViewer not extending sendMessage method --- .../test/java/it/angrybear/yagl/guis/PageableGUITest.java | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java index 915570b7..7380518a 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java @@ -244,6 +244,11 @@ public void playSound(@NotNull Sound sound) { } + @Override + public void sendMessage(@NotNull String message) { + + } + @Override public void executeCommand(@NotNull String command) { From 68b556f5826c9e6c2d0d336697673e60c123bcbc Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 16:38:04 +0200 Subject: [PATCH 096/204] Added tests for Viewer#sendMessage method --- .../angrybear/yagl/viewers/BukkitViewerTest.java | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/gui/bukkit/src/test/java/it/angrybear/yagl/viewers/BukkitViewerTest.java b/gui/bukkit/src/test/java/it/angrybear/yagl/viewers/BukkitViewerTest.java index 2a28f8b0..ecd2f86e 100644 --- a/gui/bukkit/src/test/java/it/angrybear/yagl/viewers/BukkitViewerTest.java +++ b/gui/bukkit/src/test/java/it/angrybear/yagl/viewers/BukkitViewerTest.java @@ -9,7 +9,7 @@ import java.util.UUID; import static org.junit.jupiter.api.Assertions.*; -import static org.mockito.Mockito.when; +import static org.mockito.Mockito.*; class BukkitViewerTest { private Player player; @@ -19,6 +19,7 @@ class BukkitViewerTest { void setUp() { BukkitUtils.setupServer(); this.player = BukkitUtils.addPlayer(UUID.randomUUID(), "Alex"); + when(this.player.isOnline()).thenReturn(true); this.viewer = BukkitViewer.newViewer(this.player); } @@ -28,6 +29,19 @@ void testNewViewer() { assertEquals(this.player.getName(), this.viewer.getName()); } + @Test + void testSendMessage() { + String expected = "Hello world"; + this.viewer.sendMessage(expected); + verify(this.player, atLeastOnce()).sendMessage(expected); + } + + @Test + void testSendMessageOffline() { + BukkitUtils.removePlayer(this.player); + assertThrowsExactly(PlayerOfflineException.class, () -> this.viewer.sendMessage("Message")); + } + @Test void testPlaySoundOffline() { BukkitUtils.removePlayer(this.player); From 288878afaeddfe87f49c48116770db1f28acb4a0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 16:39:45 +0200 Subject: [PATCH 097/204] Added tests for GUIAdapter#closeGUI offline player --- .../test/java/it/angrybear/yagl/GUIAdapterTest.java | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java b/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java index 19da8003..bcdf042d 100644 --- a/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java +++ b/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java @@ -130,8 +130,18 @@ void testOpenGUIForOfflinePlayer() { assertThrowsExactly(PlayerOfflineException.class, () -> openGUI(GUI.newGUI(9))); } + @Test + void testCloseGUIForOfflinePlayer() { + BukkitUtils.removePlayer(this.player); + assertThrowsExactly(PlayerOfflineException.class, this::closeGUI); + } + private void openGUI(GUI gui) { GUITestUtils.mockPlugin(p -> gui.open(GUIManager.getViewer(this.player))); } + private void closeGUI() { + GUITestUtils.mockPlugin(p -> GUIAdapter.closeGUI(GUIManager.getViewer(this.player))); + } + } \ No newline at end of file From 99b1fa9efac634578edb4c14d0b0a2c9fd6b9fcd Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 16:42:49 +0200 Subject: [PATCH 098/204] Added tests for GUIManager#getOpenGUIViewer(Player) not present --- .../src/test/java/it/angrybear/yagl/GUIManagerTest.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/gui/bukkit/src/test/java/it/angrybear/yagl/GUIManagerTest.java b/gui/bukkit/src/test/java/it/angrybear/yagl/GUIManagerTest.java index 2d37fef1..23efccf8 100644 --- a/gui/bukkit/src/test/java/it/angrybear/yagl/GUIManagerTest.java +++ b/gui/bukkit/src/test/java/it/angrybear/yagl/GUIManagerTest.java @@ -31,6 +31,14 @@ class GUIManagerTest { + @Test + void testGetOpenGUIViewerPlayer() { + BukkitUtils.setupServer(); + Player player = BukkitUtils.addPlayer(UUID.randomUUID(), "Alex"); + GUITestUtils.mockPlugin(p -> + assertFalse(GUIManager.getOpenGUIViewer(player).isPresent(), "Should not be present")); + } + @Test void testGetOpenGUIViewerUUID() { BukkitUtils.setupServer(); From 4189dda0c69292313e80f81be571f3c9c217d2dd Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 17:54:54 +0200 Subject: [PATCH 099/204] Fixed PersistentListener click tests with proper move to other inventory action --- .../it/angrybear/yagl/listeners/PersistentListenerTest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java b/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java index f9164af2..90e07bd1 100644 --- a/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java +++ b/item/bukkit/src/test/java/it/angrybear/yagl/listeners/PersistentListenerTest.java @@ -256,7 +256,7 @@ private InventoryClickEvent[] inventoryClickEvents() { @ParameterizedTest @MethodSource("inventoryClickEvents") void simulateInventoryClick(InventoryClickEvent event) { - if (event.getRawSlot() == 2) cursor = maintain.create(); + if (event.getRawSlot() == 2) cursor = maintain.setMobility(Mobility.INTERNAL).create(); assertFalse(clicked, "Clicked should be initialized as false"); assertFalse(event.isCancelled(), "Event should not be cancelled"); From 6e3fefbf048d96c894a1c763259a8cfeba606913 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 18:34:47 +0200 Subject: [PATCH 100/204] Created openpageablegui command This closes #47 --- .../resources/commands/OpenPageableGUI.groovy | 41 +++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 demo/src/main/resources/commands/OpenPageableGUI.groovy diff --git a/demo/src/main/resources/commands/OpenPageableGUI.groovy b/demo/src/main/resources/commands/OpenPageableGUI.groovy new file mode 100644 index 00000000..4ff73ab6 --- /dev/null +++ b/demo/src/main/resources/commands/OpenPageableGUI.groovy @@ -0,0 +1,41 @@ +import it.angrybear.yagl.GUIManager +import it.angrybear.yagl.guis.GUIType +import it.angrybear.yagl.guis.PageableGUI +import it.angrybear.yagl.items.BukkitItem +import it.angrybear.yagl.items.Item +import it.angrybear.yagl.utils.EnumUtils +import org.bukkit.Material +import org.bukkit.entity.Player + +def run = { sender, label, args -> + if (sender instanceof Player) + try { + PageableGUI gui + try { + gui = PageableGUI.newGUI(EnumUtils.valueOf(GUIType, args[0])).setPages(Integer.valueOf(args[1])) + } catch (IllegalArgumentException ignored) { + gui = PageableGUI.newGUI(Integer.valueOf(args[0])).setPages(Integer.valueOf(args[1])) + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage("Usage: /openpageablegui ") + return + } + def size = gui.size() + def middle = (int) (size / 2) + if (size > 1) gui.setContents(middle, BukkitItem.newItem(Material.OBSIDIAN).setDisplayName("&7Page: &e")) + .setPreviousPage(0, BukkitItem.newItem(Material.REDSTONE_BLOCK) + .setDisplayName("&7Go to page &e")) + .setNextPage(size - 1, BukkitItem.newItem(Material.EMERALD_BLOCK) + .setDisplayName("&7Go to page &e")) + + gui.setTitle("Page #") + .onClickOutside((v, g) -> v.sendMessage('Please only click inside me!')) + .onOpenGUI((v, g) -> v.sendMessage(g.apply('Opening page '))) + .onCloseGUI((v, g) -> v.sendMessage('Goodbye!')) + .open(GUIManager.getViewer(sender)) + } catch (NumberFormatException ignored) { + + } catch (Exception e) { + sender.sendMessage(e.getMessage()) + } + else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From 3cf2dcf510626ca2346b4db9f3d6e7c537d3ea76 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 19:16:19 +0200 Subject: [PATCH 101/204] Updated FulmiCollection --- .../src/main/java/it/angrybear/yagl/utils/ObjectUtils.java | 4 +++- gradle/libs.versions.toml | 2 +- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java index bbef50b0..b6a6c085 100644 --- a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java +++ b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java @@ -1,6 +1,7 @@ package it.angrybear.yagl.utils; import it.fulminazzo.fulmicollection.objects.Refl; +import it.fulminazzo.fulmicollection.structures.NullableOptional; import it.fulminazzo.fulmicollection.utils.ReflectionUtils; import lombok.AccessLevel; import lombok.NoArgsConstructor; @@ -88,7 +89,8 @@ public static O copy(final @NotNull T t, @NotNull Class claz } else try { Method copy = obj1.getClass().getDeclaredMethod("copy"); - obj1 = ReflectionUtils.setAccessible(copy).invoke(obj1); + @NotNull NullableOptional optional = ReflectionUtils.setAccessible(copy); + if (optional.isPresent()) obj1 = optional.get().invoke(obj1); } catch (InvocationTargetException | NoSuchMethodException | IllegalAccessException ignored) {} object.setFieldObject(field, obj1); } catch (IllegalArgumentException ignored) {} diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 89d8bc27..dbc601d9 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -2,7 +2,7 @@ delombok = "8.4" groovy = "4.0.16" -fulmicollection = "1.5.2" +fulmicollection = "1.5.3" yamlparser = "1.6.2" spigot = "1.14-R0.1-SNAPSHOT" From 802686495a466a9506644daf81b2b8a1407f660a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 19:20:12 +0200 Subject: [PATCH 102/204] Reworked apply method to check if accessibility was successful --- .../src/main/java/it/angrybear/yagl/Metadatable.java | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java b/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java index 5b70bb0f..be0efac8 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java +++ b/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java @@ -129,10 +129,14 @@ default T apply(final T object) { else if (object instanceof Map) return (T) apply((Map) object); else if (!ReflectionUtils.isPrimitiveOrWrapper(object.getClass())) { final Refl refl = new Refl<>(object); - for (Field field : refl.getNonStaticFields()) { - Object o = refl.getFieldObject(field); - refl.setFieldObject(field, apply(o)); - } + for (Field field : refl.getNonStaticFields()) + ReflectionUtils.setAccessible(field).ifPresent(f -> { + try { + refl.setFieldObject(f, apply(f.get(object))); + } catch (IllegalAccessException e) { + throw new RuntimeException(e); + } + }); } return object; } From a8513edf8dc48a98a22a502f748a971644553d45 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 19:25:56 +0200 Subject: [PATCH 103/204] Reworked positioning of items --- .../resources/commands/OpenPageableGUI.groovy | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/demo/src/main/resources/commands/OpenPageableGUI.groovy b/demo/src/main/resources/commands/OpenPageableGUI.groovy index 4ff73ab6..1c16fcb3 100644 --- a/demo/src/main/resources/commands/OpenPageableGUI.groovy +++ b/demo/src/main/resources/commands/OpenPageableGUI.groovy @@ -2,7 +2,6 @@ import it.angrybear.yagl.GUIManager import it.angrybear.yagl.guis.GUIType import it.angrybear.yagl.guis.PageableGUI import it.angrybear.yagl.items.BukkitItem -import it.angrybear.yagl.items.Item import it.angrybear.yagl.utils.EnumUtils import org.bukkit.Material import org.bukkit.entity.Player @@ -20,12 +19,15 @@ def run = { sender, label, args -> return } def size = gui.size() - def middle = (int) (size / 2) - if (size > 1) gui.setContents(middle, BukkitItem.newItem(Material.OBSIDIAN).setDisplayName("&7Page: &e")) - .setPreviousPage(0, BukkitItem.newItem(Material.REDSTONE_BLOCK) - .setDisplayName("&7Go to page &e")) - .setNextPage(size - 1, BukkitItem.newItem(Material.EMERALD_BLOCK) - .setDisplayName("&7Go to page &e")) + def middle = (int) Math.min(size / 2, 9 / 2) + if (size > 1) { + size -= 1 + gui.setContents(size - middle, BukkitItem.newItem(Material.OBSIDIAN).setDisplayName("&7Page: &e")) + .setPreviousPage(size - middle * 2, BukkitItem.newItem(Material.REDSTONE_BLOCK) + .setDisplayName("&7Go to page &e")) + .setNextPage(size, BukkitItem.newItem(Material.EMERALD_BLOCK) + .setDisplayName("&7Go to page &e")) + } gui.setTitle("Page #") .onClickOutside((v, g) -> v.sendMessage('Please only click inside me!')) From 3d868e3dc739f857f74410789408f607d7fd8d4c Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Tue, 16 Apr 2024 19:35:55 +0200 Subject: [PATCH 104/204] Reworked GUIAdapter#openGUI function to not close inventory in case of changing GUI. This allows to more seamless transition between GUIs --- .../src/main/java/it/angrybear/yagl/GUIAdapter.java | 9 +++++---- .../src/main/java/it/angrybear/yagl/GUIManager.java | 7 ------- .../test/java/it/angrybear/yagl/GUIManagerTest.java | 12 ------------ 3 files changed, 5 insertions(+), 23 deletions(-) diff --git a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java index d18ab381..6aeea1df 100644 --- a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java +++ b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIAdapter.java @@ -73,12 +73,9 @@ public static void openGUI(final @NotNull GUI gui, @NotNull GUIManager.getOpenGUIViewer(uuid).ifPresent((v, g) -> { reflViewer.setFieldObject("previousGUI", g).setFieldObject("openGUI", null); g.changeGUIAction().ifPresent(a -> a.execute(v, g, gui)); - player.closeInventory(); }); - // Set new GUI - reflViewer.setFieldObject("openGUI", gui.apply(gui)); // Open inventory - Inventory inventory = guiToInventory(gui); + Inventory inventory = guiToInventory(gui.apply(gui)); for (int i = 0; i < gui.size(); i++) { GUIContent content = gui.getContent(viewer, i); if (content != null) { @@ -90,6 +87,10 @@ public static void openGUI(final @NotNull GUI gui, @NotNull } } player.openInventory(inventory); + // Set new GUI + reflViewer.setFieldObject("openGUI", gui); + // Execute action if present + gui.openGUIAction().ifPresent(a -> a.execute(reflViewer.getObject(), gui)); } /** diff --git a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java index c8da6980..6806392e 100644 --- a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java +++ b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java @@ -13,7 +13,6 @@ import org.bukkit.event.inventory.InventoryClickEvent; import org.bukkit.event.inventory.InventoryCloseEvent; import org.bukkit.event.inventory.InventoryDragEvent; -import org.bukkit.event.inventory.InventoryOpenEvent; import org.bukkit.event.server.PluginDisableEvent; import org.bukkit.plugin.Plugin; import org.bukkit.plugin.java.JavaPlugin; @@ -42,12 +41,6 @@ public GUIManager() { this.viewers = new ArrayList<>(); } - @EventHandler - void on(final @NotNull InventoryOpenEvent event) { - getOpenGUIViewer(event.getPlayer()).ifPresent((v, g) -> - g.openGUIAction().ifPresent(a -> a.execute(v, g))); - } - @EventHandler void on(final @NotNull InventoryClickEvent event) { getOpenGUIViewer(event.getWhoClicked()).ifPresent((v, g) -> { diff --git a/gui/bukkit/src/test/java/it/angrybear/yagl/GUIManagerTest.java b/gui/bukkit/src/test/java/it/angrybear/yagl/GUIManagerTest.java index 23efccf8..1aee6cde 100644 --- a/gui/bukkit/src/test/java/it/angrybear/yagl/GUIManagerTest.java +++ b/gui/bukkit/src/test/java/it/angrybear/yagl/GUIManagerTest.java @@ -183,18 +183,6 @@ void testClickOutside() { assertTrue(expected.get(), "Outside action was not invoked"); } - @Test - void testOpenEvent() { - AtomicBoolean expected = new AtomicBoolean(false); - this.expected.onOpenGUI((v, g) -> expected.set(true)); - - InventoryView view = getView(); - - this.guiManager.on(new InventoryOpenEvent(view)); - - assertTrue(expected.get(), "OpenGUI action was not invoked"); - } - @Test void testDragEvent() { InventoryView view = getView(); From 1d1443bc35bf7ff1e77280153261ab8aec923c3a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 10:39:27 +0200 Subject: [PATCH 105/204] Updated FulmiCollection --- gradle/libs.versions.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index dbc601d9..57073d74 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -2,7 +2,7 @@ delombok = "8.4" groovy = "4.0.16" -fulmicollection = "1.5.3" +fulmicollection = "1.6" yamlparser = "1.6.2" spigot = "1.14-R0.1-SNAPSHOT" From 92972fb9c507e477b326f4f1c173d6b7c6bc17c2 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 10:40:29 +0200 Subject: [PATCH 106/204] Fixed every reference to Tuple and Triple packages --- demo/src/main/resources/commands/GetEnchantment.groovy | 2 +- .../src/main/java/it/angrybear/yagl/guis/PageableGUI.java | 2 +- .../src/test/java/it/angrybear/yagl/guis/PageableGUITest.java | 2 +- .../java/it/angrybear/yagl/parsers/PageableGUIParser.java | 2 +- item/bukkit/src/main/java/it/angrybear/yagl/ItemAdapter.java | 2 +- .../java/it/angrybear/yagl/particles/DustParticleOption.java | 2 +- .../yagl/particles/DustTransitionParticleOption.java | 2 +- .../java/it/angrybear/yagl/particles/MaterialDataOption.java | 2 +- .../src/main/java/it/angrybear/yagl/WrappersAdapter.java | 4 ++-- .../src/test/java/it/angrybear/yagl/WrappersAdapterTest.java | 2 +- .../it/angrybear/yagl/particles/MaterialDataOptionParser.java | 2 +- 11 files changed, 12 insertions(+), 12 deletions(-) diff --git a/demo/src/main/resources/commands/GetEnchantment.groovy b/demo/src/main/resources/commands/GetEnchantment.groovy index adea3eb3..e687593e 100644 --- a/demo/src/main/resources/commands/GetEnchantment.groovy +++ b/demo/src/main/resources/commands/GetEnchantment.groovy @@ -1,6 +1,6 @@ import it.angrybear.yagl.WrappersAdapter import it.angrybear.yagl.wrappers.Enchantment -import it.fulminazzo.fulmicollection.structures.Tuple +import it.fulminazzo.fulmicollection.structures.tuples.Tuple import org.bukkit.Material import org.bukkit.entity.Player import org.bukkit.inventory.ItemStack diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java index 6e866c5d..acedf370 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java @@ -8,7 +8,7 @@ import it.angrybear.yagl.items.Item; import it.angrybear.yagl.viewers.Viewer; import it.fulminazzo.fulmicollection.objects.FieldEquable; -import it.fulminazzo.fulmicollection.structures.Tuple; +import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java index 7380518a..d8b896c2 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java @@ -9,7 +9,7 @@ import it.angrybear.yagl.viewers.Viewer; import it.angrybear.yagl.wrappers.Sound; import it.fulminazzo.fulmicollection.objects.Refl; -import it.fulminazzo.fulmicollection.structures.Tuple; +import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import it.fulminazzo.fulmicollection.utils.ReflectionUtils; import org.jetbrains.annotations.NotNull; import org.junit.jupiter.api.Test; diff --git a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java index d0c852a2..d90ed7db 100644 --- a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java +++ b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java @@ -7,7 +7,7 @@ import it.fulminazzo.fulmicollection.interfaces.functions.BiFunctionException; import it.fulminazzo.fulmicollection.interfaces.functions.TriConsumer; import it.fulminazzo.fulmicollection.objects.Refl; -import it.fulminazzo.fulmicollection.structures.Tuple; +import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import it.fulminazzo.yamlparser.configuration.ConfigurationSection; import it.fulminazzo.yamlparser.configuration.IConfiguration; import it.fulminazzo.yamlparser.parsers.YAMLParser; diff --git a/item/bukkit/src/main/java/it/angrybear/yagl/ItemAdapter.java b/item/bukkit/src/main/java/it/angrybear/yagl/ItemAdapter.java index 4f4c3e49..a8948a2c 100644 --- a/item/bukkit/src/main/java/it/angrybear/yagl/ItemAdapter.java +++ b/item/bukkit/src/main/java/it/angrybear/yagl/ItemAdapter.java @@ -9,7 +9,7 @@ import it.angrybear.yagl.items.recipes.ShapelessRecipe; import it.angrybear.yagl.utils.EnumUtils; import it.fulminazzo.fulmicollection.objects.Refl; -import it.fulminazzo.fulmicollection.structures.Tuple; +import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import lombok.AccessLevel; import lombok.NoArgsConstructor; import org.bukkit.Bukkit; diff --git a/wrappers/base/src/main/java/it/angrybear/yagl/particles/DustParticleOption.java b/wrappers/base/src/main/java/it/angrybear/yagl/particles/DustParticleOption.java index 23235d3a..d9fdb357 100644 --- a/wrappers/base/src/main/java/it/angrybear/yagl/particles/DustParticleOption.java +++ b/wrappers/base/src/main/java/it/angrybear/yagl/particles/DustParticleOption.java @@ -1,7 +1,7 @@ package it.angrybear.yagl.particles; import it.angrybear.yagl.Color; -import it.fulminazzo.fulmicollection.structures.Tuple; +import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import org.jetbrains.annotations.NotNull; /** diff --git a/wrappers/base/src/main/java/it/angrybear/yagl/particles/DustTransitionParticleOption.java b/wrappers/base/src/main/java/it/angrybear/yagl/particles/DustTransitionParticleOption.java index e6fd7369..1bbdc781 100644 --- a/wrappers/base/src/main/java/it/angrybear/yagl/particles/DustTransitionParticleOption.java +++ b/wrappers/base/src/main/java/it/angrybear/yagl/particles/DustTransitionParticleOption.java @@ -1,7 +1,7 @@ package it.angrybear.yagl.particles; import it.angrybear.yagl.Color; -import it.fulminazzo.fulmicollection.structures.Triple; +import it.fulminazzo.fulmicollection.structures.tuples.Triple; import org.jetbrains.annotations.NotNull; /** diff --git a/wrappers/base/src/main/java/it/angrybear/yagl/particles/MaterialDataOption.java b/wrappers/base/src/main/java/it/angrybear/yagl/particles/MaterialDataOption.java index eef94544..9855e4f9 100644 --- a/wrappers/base/src/main/java/it/angrybear/yagl/particles/MaterialDataOption.java +++ b/wrappers/base/src/main/java/it/angrybear/yagl/particles/MaterialDataOption.java @@ -1,6 +1,6 @@ package it.angrybear.yagl.particles; -import it.fulminazzo.fulmicollection.structures.Tuple; +import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import org.jetbrains.annotations.NotNull; /** diff --git a/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java b/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java index 26d11ebc..a7ceee1b 100644 --- a/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java +++ b/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java @@ -10,8 +10,8 @@ import it.angrybear.yagl.wrappers.Sound; import it.fulminazzo.fulmicollection.objects.Refl; import it.fulminazzo.fulmicollection.structures.CacheMap; -import it.fulminazzo.fulmicollection.structures.Triple; -import it.fulminazzo.fulmicollection.structures.Tuple; +import it.fulminazzo.fulmicollection.structures.tuples.Triple; +import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import it.fulminazzo.fulmicollection.utils.ReflectionUtils; import lombok.AccessLevel; import lombok.NoArgsConstructor; diff --git a/wrappers/bukkit/src/test/java/it/angrybear/yagl/WrappersAdapterTest.java b/wrappers/bukkit/src/test/java/it/angrybear/yagl/WrappersAdapterTest.java index 295b9558..9fe20aa3 100644 --- a/wrappers/bukkit/src/test/java/it/angrybear/yagl/WrappersAdapterTest.java +++ b/wrappers/bukkit/src/test/java/it/angrybear/yagl/WrappersAdapterTest.java @@ -7,7 +7,7 @@ import it.angrybear.yagl.wrappers.PotionEffect; import it.angrybear.yagl.wrappers.Sound; import it.fulminazzo.fulmicollection.objects.Refl; -import it.fulminazzo.fulmicollection.structures.Tuple; +import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import it.fulminazzo.fulmicollection.utils.ReflectionUtils; import it.fulminazzo.jbukkit.BukkitUtils; import it.fulminazzo.jbukkit.annotations.After1_; diff --git a/wrappers/serializer/src/main/java/it/angrybear/yagl/particles/MaterialDataOptionParser.java b/wrappers/serializer/src/main/java/it/angrybear/yagl/particles/MaterialDataOptionParser.java index 27da299e..2f149f0c 100644 --- a/wrappers/serializer/src/main/java/it/angrybear/yagl/particles/MaterialDataOptionParser.java +++ b/wrappers/serializer/src/main/java/it/angrybear/yagl/particles/MaterialDataOptionParser.java @@ -2,7 +2,7 @@ import it.fulminazzo.fulmicollection.interfaces.functions.BiFunctionException; import it.fulminazzo.fulmicollection.interfaces.functions.TriConsumer; -import it.fulminazzo.fulmicollection.structures.Tuple; +import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import it.fulminazzo.yamlparser.configuration.IConfiguration; import it.fulminazzo.yamlparser.parsers.YAMLParser; From bb7b5422e7ed25e4202a35074e4a934dddeb768e Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 10:42:15 +0200 Subject: [PATCH 107/204] Replaced every BiOptional with Tuple --- .../java/it/angrybear/yagl/GUIManager.java | 22 +++++++++---------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java index 6806392e..6012ad84 100644 --- a/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java +++ b/gui/bukkit/src/main/java/it/angrybear/yagl/GUIManager.java @@ -4,7 +4,7 @@ import it.angrybear.yagl.guis.GUI; import it.angrybear.yagl.viewers.Viewer; import it.fulminazzo.fulmicollection.objects.Refl; -import it.fulminazzo.fulmicollection.structures.BiOptional; +import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import it.fulminazzo.fulmicollection.utils.ReflectionUtils; import org.bukkit.Bukkit; import org.bukkit.entity.HumanEntity; @@ -80,27 +80,27 @@ void on(final @NotNull PluginDisableEvent event) { } /** - * Gets a {@link BiOptional} with the corresponding {@link Viewer} and open {@link GUI} if present. + * Gets a {@link Tuple} with the corresponding {@link Viewer} and open {@link GUI} if present. * * @param player the player - * @return the BiOptional + * @return the Tuple */ - public static @NotNull BiOptional getOpenGUIViewer(final @NotNull HumanEntity player) { + public static @NotNull Tuple getOpenGUIViewer(final @NotNull HumanEntity player) { Viewer viewer = getViewer(player); - if (viewer.hasOpenGUI()) return BiOptional.of(viewer, viewer.getOpenGUI()); - else return BiOptional.empty(); + if (viewer.hasOpenGUI()) return new Tuple<>(viewer, viewer.getOpenGUI()); + else return new Tuple<>(); } /** - * Gets a {@link BiOptional} with the corresponding {@link Viewer} and open {@link GUI} if present. + * Gets a {@link Tuple} with the corresponding {@link Viewer} and open {@link GUI} if present. * * @param uuid the uuid - * @return the BiOptional + * @return the Tuple */ - public static @NotNull BiOptional getOpenGUIViewer(final @NotNull UUID uuid) { + public static @NotNull Tuple getOpenGUIViewer(final @NotNull UUID uuid) { Viewer viewer = getViewer(uuid); - if (viewer != null && viewer.hasOpenGUI()) return BiOptional.of(viewer, viewer.getOpenGUI()); - else return BiOptional.empty(); + if (viewer != null && viewer.hasOpenGUI()) return new Tuple<>(viewer, viewer.getOpenGUI()); + else return new Tuple<>(); } /** From cdc786a84a158ef1103ec44559d29ec5583df790 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 10:47:49 +0200 Subject: [PATCH 108/204] Extracted various copy methods --- .../it/angrybear/yagl/utils/ObjectUtils.java | 32 +++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java index b6a6c085..80b13fce 100644 --- a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java +++ b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java @@ -98,4 +98,36 @@ public static O copy(final @NotNull T t, @NotNull Class claz return object.getObject(); } + private static @NotNull Object[] copyArray(final @NotNull Object obj1) { + Object[] tmp = (Object[]) obj1; + Object[] arr = (Object[]) Array.newInstance(obj1.getClass().getComponentType(), tmp.length); + System.arraycopy(tmp, 0, arr, 0, arr.length); + return arr; + } + + private static @NotNull Map copyMap(final @NotNull Object obj1) { + Map map = new HashMap<>(); + ((Map) obj1).putAll(map); + return map; + } + + private static @NotNull Collection copyCollection(final @NotNull Object obj1) { + Class tmpClass = obj1.getClass(); + // In the case of creation with Arrays.asList() + if (tmpClass.getCanonicalName().equals(Arrays.class.getCanonicalName() + ".ArrayList")) + tmpClass = ArrayList.class; + Class> finalClass = (Class>) tmpClass; + return ((Collection) obj1).stream() + .collect(Collectors.toCollection(() -> new Refl<>(finalClass, new Object[0]).getObject())); + } + + private static @NotNull Object copyWthMethod(final @NotNull Object obj1) { + try { + Method copy = obj1.getClass().getDeclaredMethod("copy"); + @NotNull NullableOptional optional = ReflectionUtils.setAccessible(copy); + if (optional.isPresent()) obj1 = optional.get().invoke(obj1); + } catch (InvocationTargetException | NoSuchMethodException | IllegalAccessException ignored) {} + return obj1; + } + } From 3064154850c15d0845ed1a4de6a938d7c65b8364 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 10:48:09 +0200 Subject: [PATCH 109/204] Totally reworked copy method for with new optional methods --- .../it/angrybear/yagl/utils/ObjectUtils.java | 38 ++++--------------- 1 file changed, 8 insertions(+), 30 deletions(-) diff --git a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java index 80b13fce..2869f0c8 100644 --- a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java +++ b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java @@ -64,37 +64,15 @@ public static O copy(final @NotNull T t, @NotNull Class claz clazz.getCanonicalName(), clazz.getCanonicalName())); } - Refl object = new Refl<>(clazz, new Object[0]); + final Refl object = new Refl<>(clazz, new Object[0]); for (final Field field : object.getNonStaticFields()) - try { - Object obj1 = ReflectionUtils.get(field, t); - if (obj1 instanceof Collection) { - Class tmpClass = obj1.getClass(); - // In the case of creation with Arrays.asList() - if (tmpClass.getCanonicalName().equals(Arrays.class.getCanonicalName() + ".ArrayList")) - tmpClass = ArrayList.class; - Class> finalClass = (Class>) tmpClass; - obj1 = ((Collection) obj1).stream() - .collect(Collectors.toCollection(() -> new Refl<>(finalClass, new Object[0]).getObject())); - } else if (obj1 instanceof Map) { - Map map = new HashMap<>(); - ((Map) obj1).putAll(map); - obj1 = map; - } else if (obj1 != null) - if (obj1.getClass().isArray()) { - Object[] tmp = (Object[]) obj1; - Object[] arr = (Object[]) Array.newInstance(obj1.getClass().getComponentType(), tmp.length); - System.arraycopy(tmp, 0, arr, 0, arr.length); - obj1 = arr; - } else - try { - Method copy = obj1.getClass().getDeclaredMethod("copy"); - @NotNull NullableOptional optional = ReflectionUtils.setAccessible(copy); - if (optional.isPresent()) obj1 = optional.get().invoke(obj1); - } catch (InvocationTargetException | NoSuchMethodException | IllegalAccessException ignored) {} - object.setFieldObject(field, obj1); - } catch (IllegalArgumentException ignored) {} - + ReflectionUtils.get(field, t).map(obj1 -> { + if (obj1 == null) return null; + else if (obj1 instanceof Collection) return copyCollection(obj1); + else if (obj1 instanceof Map) return copyMap(obj1); + else if (obj1.getClass().isArray()) return copyArray(obj1); + else return copyWthMethod(obj1); + }).ifPresent(obj1 -> object.setFieldObject(field, obj1)); return object.getObject(); } From 1fce2f083e602e98bff84de223111fdd9f2d1cca Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 10:50:07 +0200 Subject: [PATCH 110/204] Reworked copyWithMethod function --- .../it/angrybear/yagl/utils/ObjectUtils.java | 20 +++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java index 2869f0c8..c80c351d 100644 --- a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java +++ b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java @@ -1,13 +1,15 @@ package it.angrybear.yagl.utils; import it.fulminazzo.fulmicollection.objects.Refl; -import it.fulminazzo.fulmicollection.structures.NullableOptional; import it.fulminazzo.fulmicollection.utils.ReflectionUtils; import lombok.AccessLevel; import lombok.NoArgsConstructor; import org.jetbrains.annotations.NotNull; -import java.lang.reflect.*; +import java.lang.reflect.Array; +import java.lang.reflect.Field; +import java.lang.reflect.Method; +import java.lang.reflect.Modifier; import java.util.*; import java.util.stream.Collectors; @@ -71,7 +73,7 @@ public static O copy(final @NotNull T t, @NotNull Class claz else if (obj1 instanceof Collection) return copyCollection(obj1); else if (obj1 instanceof Map) return copyMap(obj1); else if (obj1.getClass().isArray()) return copyArray(obj1); - else return copyWthMethod(obj1); + else return copyWithMethod(obj1); }).ifPresent(obj1 -> object.setFieldObject(field, obj1)); return object.getObject(); } @@ -99,13 +101,15 @@ public static O copy(final @NotNull T t, @NotNull Class claz .collect(Collectors.toCollection(() -> new Refl<>(finalClass, new Object[0]).getObject())); } - private static @NotNull Object copyWthMethod(final @NotNull Object obj1) { + private static @NotNull Object copyWithMethod(final @NotNull Object obj1) { try { Method copy = obj1.getClass().getDeclaredMethod("copy"); - @NotNull NullableOptional optional = ReflectionUtils.setAccessible(copy); - if (optional.isPresent()) obj1 = optional.get().invoke(obj1); - } catch (InvocationTargetException | NoSuchMethodException | IllegalAccessException ignored) {} - return obj1; + return ReflectionUtils.setAccessible(copy) + .map(m -> m.invoke(obj1)) + .orElseGet(obj1); + } catch (NoSuchMethodException e) { + return obj1; + } } } From 6abe66f1afc25c5d4ea9aa5ef6ab64f07ed39fbf Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 10:55:46 +0200 Subject: [PATCH 111/204] Updated ReflectionUtils references --- common/base/src/main/java/it/angrybear/yagl/ClassEnum.java | 3 ++- .../java/it/angrybear/yagl/contents/ItemGUIContentTest.java | 4 ++-- .../test/java/it/angrybear/yagl/guis/PageableGUITest.java | 2 +- .../src/test/java/it/angrybear/yagl/ItemAdapterTest.java | 2 +- testing/src/main/java/it/angrybear/yagl/TestUtils.java | 6 +++--- 5 files changed, 9 insertions(+), 8 deletions(-) diff --git a/common/base/src/main/java/it/angrybear/yagl/ClassEnum.java b/common/base/src/main/java/it/angrybear/yagl/ClassEnum.java index def3551d..eed10be7 100644 --- a/common/base/src/main/java/it/angrybear/yagl/ClassEnum.java +++ b/common/base/src/main/java/it/angrybear/yagl/ClassEnum.java @@ -129,7 +129,8 @@ private void checkValues() { if (!this.values.isEmpty()) return; for (Field field : this.clazz.getDeclaredFields()) if (field.getType().equals(this.clazz)) - this.values.put(field.getName().toUpperCase(), ReflectionUtils.get(field, this.clazz)); + ReflectionUtils.get(field, this.clazz).ifPresent(o -> + this.values.put(field.getName().toUpperCase(), (T) o)); } } } diff --git a/gui/base/src/test/java/it/angrybear/yagl/contents/ItemGUIContentTest.java b/gui/base/src/test/java/it/angrybear/yagl/contents/ItemGUIContentTest.java index 8232f18c..2ab4e5ac 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/contents/ItemGUIContentTest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/contents/ItemGUIContentTest.java @@ -53,8 +53,8 @@ void testItemMethods() throws InvocationTargetException, IllegalAccessException if (method.getName().equals("isSimilar")) params = new Object[]{expected, new ItemField[0]}; else params = Arrays.stream(method.getParameterTypes()).map(TestUtils::mockParameter).toArray(Object[]::new); - Object obj1 = ReflectionUtils.setAccessible(method).invoke(actual, params); - Object obj2 = ReflectionUtils.setAccessible(method).invoke(expected, params); + Object obj1 = ReflectionUtils.setAccessibleOrThrow(method).invoke(actual, params); + Object obj2 = ReflectionUtils.setAccessibleOrThrow(method).invoke(expected, params); assertEquals(obj2, obj1); } } diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java index d8b896c2..77811727 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java @@ -136,7 +136,7 @@ void testPageableGUIMethods() throws InvocationTargetException, IllegalAccessExc Metadatable.class.getDeclaredMethod(method.getName(), method.getParameterTypes()); continue; } catch (NoSuchMethodException ignored) {} - method = ReflectionUtils.setAccessible(method); + method = ReflectionUtils.setAccessibleOrThrow(method); Object[] params = Arrays.stream(method.getParameterTypes()) .map(TestUtils::mockParameter) .map(o -> o instanceof Integer ? 0 : o) diff --git a/item/bukkit/src/test/java/it/angrybear/yagl/ItemAdapterTest.java b/item/bukkit/src/test/java/it/angrybear/yagl/ItemAdapterTest.java index b1e47489..e6ddd475 100644 --- a/item/bukkit/src/test/java/it/angrybear/yagl/ItemAdapterTest.java +++ b/item/bukkit/src/test/java/it/angrybear/yagl/ItemAdapterTest.java @@ -156,7 +156,7 @@ void testNullRecipe() throws InvocationTargetException, IllegalAccessException { @NotNull List methods = adapter.getMethods(m -> m.getName().equals(methodName)); assertEquals(4, methods.size(), String.format("Could not find all '%s' methods", methodName)); for (Method method : methods) { - Object result = ReflectionUtils.setAccessible(method).invoke(ItemAdapter.class, (Object) null); + Object result = ReflectionUtils.setAccessibleOrThrow(method).invoke(ItemAdapter.class, (Object) null); assertNull(result); } } diff --git a/testing/src/main/java/it/angrybear/yagl/TestUtils.java b/testing/src/main/java/it/angrybear/yagl/TestUtils.java index 45d9157f..917c5a52 100644 --- a/testing/src/main/java/it/angrybear/yagl/TestUtils.java +++ b/testing/src/main/java/it/angrybear/yagl/TestUtils.java @@ -85,11 +85,11 @@ public static void testMultipleMethods(final @NotNull Object executor, final @No try { // Execute target method final Object[] parameters = initializeParameters(targetMethod.getParameterTypes(), staticObjects); - ReflectionUtils.setAccessible(targetMethod).invoke(executor, parameters); + ReflectionUtils.setAccessibleOrThrow(targetMethod).invoke(executor, parameters); // Verify execution with mock Method method = target.getClass().getDeclaredMethod(invokedMethod, invokedMethodParamTypes); - ReflectionUtils.setAccessible(method).invoke(verify(target), + ReflectionUtils.setAccessibleOrThrow(method).invoke(verify(target), Arrays.stream(captors).map(ArgumentCaptor::capture).toArray(Object[]::new)); return captors; @@ -169,7 +169,7 @@ public static void testReturnType(final @NotNull T object, final @NotNull Cl methodString, objectClassName); Object[] mockParameters = Arrays.stream(parameters).map(TestUtils::mockParameter).toArray(Object[]::new); - Object o = ReflectionUtils.setAccessible(method).invoke(object, mockParameters); + Object o = ReflectionUtils.setAccessibleOrThrow(method).invoke(object, mockParameters); if (method.getName().equals("copy")) assertInstanceOf(objectClass, o, String.format("Returned object from %s call should have been %s but was %s", From 9d9d04ed66a15a673adf7dee5ff0d629024e9a70 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 11:04:01 +0200 Subject: [PATCH 112/204] Updated YAMLParser --- gradle/libs.versions.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 57073d74..cafc6391 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -3,7 +3,7 @@ delombok = "8.4" groovy = "4.0.16" fulmicollection = "1.6" -yamlparser = "1.6.2" +yamlparser = "1.6.3" spigot = "1.14-R0.1-SNAPSHOT" spigot_obsolete = "1.8.8-R0.1-SNAPSHOT" From e3a84954e0e6be2c17cecc6f3db1ab5c544679a8 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 11:10:12 +0200 Subject: [PATCH 113/204] Updated ReflectionUtils references --- item/base/src/test/java/it/angrybear/yagl/items/ItemTest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/item/base/src/test/java/it/angrybear/yagl/items/ItemTest.java b/item/base/src/test/java/it/angrybear/yagl/items/ItemTest.java index b083c009..80a66a1e 100644 --- a/item/base/src/test/java/it/angrybear/yagl/items/ItemTest.java +++ b/item/base/src/test/java/it/angrybear/yagl/items/ItemTest.java @@ -79,7 +79,7 @@ void testCopyItemFromAbstractWithNoImpl(Class clazz) { assertTrue(message.contains(implName), "Exception message did not contain abstract implementation class name"); // Check that the returned exception is not from ReflectionUtils - String reflMessage = ReflectionUtils.get(ReflectionUtils.getField(ReflectionUtils.class, "CLASS_NOT_FOUND"), ReflectionUtils.class); + String reflMessage = ReflectionUtils.getOrThrow(ReflectionUtils.getField(ReflectionUtils.class, "CLASS_NOT_FOUND"), ReflectionUtils.class); assertNotEquals(reflMessage.replace("%class%", implName), message, "Exception message should not be the same as the one returned by ReflectionUtils"); } From 83346a5f25a538c56cedc93d82ceebacea678026 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 11:16:09 +0200 Subject: [PATCH 114/204] Fixed copy method throwing exception for invalid fields --- .../it/angrybear/yagl/utils/ObjectUtils.java | 22 ++++++++++++------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java index c80c351d..77546c28 100644 --- a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java +++ b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java @@ -67,14 +67,20 @@ public static O copy(final @NotNull T t, @NotNull Class claz } final Refl object = new Refl<>(clazz, new Object[0]); - for (final Field field : object.getNonStaticFields()) - ReflectionUtils.get(field, t).map(obj1 -> { - if (obj1 == null) return null; - else if (obj1 instanceof Collection) return copyCollection(obj1); - else if (obj1 instanceof Map) return copyMap(obj1); - else if (obj1.getClass().isArray()) return copyArray(obj1); - else return copyWithMethod(obj1); - }).ifPresent(obj1 -> object.setFieldObject(field, obj1)); + for (final Field field : object.getNonStaticFields()) { + field.setAccessible(true); + try { + ReflectionUtils.get(field, t).map(obj1 -> { + if (obj1 == null) return null; + else if (obj1 instanceof Collection) return copyCollection(obj1); + else if (obj1 instanceof Map) return copyMap(obj1); + else if (obj1.getClass().isArray()) return copyArray(obj1); + else return copyWithMethod(obj1); + }).ifPresent(obj1 -> object.setFieldObject(field, obj1)); + } catch (IllegalArgumentException e) { + if (!e.getMessage().contains("Can not set")) throw e; + } + } return object.getObject(); } From f785679ad63f935cf7efb44a64cf730eb036ae3c Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 11:19:31 +0200 Subject: [PATCH 115/204] Updated ReflectionUtils references --- .../test/java/it/angrybear/yagl/parsers/GUIParserTest.java | 4 ++-- item/base/src/main/java/it/angrybear/yagl/items/ItemImpl.java | 4 ++-- .../test/java/it/angrybear/yagl/parsers/RecipeParserTest.java | 4 ++-- .../src/test/java/it/angrybear/yagl/WrappersAdapterTest.java | 4 ++-- .../it/angrybear/yagl/particles/ParticleOptionParserTest.java | 4 ++-- .../java/it/angrybear/yagl/particles/ParticleParserTest.java | 4 ++-- 6 files changed, 12 insertions(+), 12 deletions(-) diff --git a/gui/serializer/src/test/java/it/angrybear/yagl/parsers/GUIParserTest.java b/gui/serializer/src/test/java/it/angrybear/yagl/parsers/GUIParserTest.java index ace3f010..6e214156 100644 --- a/gui/serializer/src/test/java/it/angrybear/yagl/parsers/GUIParserTest.java +++ b/gui/serializer/src/test/java/it/angrybear/yagl/parsers/GUIParserTest.java @@ -88,8 +88,8 @@ void testSaveAndLoadGUI(GUI expected) throws IOException { for (final Field field : new Refl<>(expected).getNonStaticFields()) if (!field.getName().equals("contents")) { - Object obj1 = ReflectionUtils.get(field, expected); - Object obj2 = ReflectionUtils.get(field, actual); + Object obj1 = ReflectionUtils.getOrThrow(field, expected); + Object obj2 = ReflectionUtils.getOrThrow(field, actual); assertEquals(obj1, obj2); } diff --git a/item/base/src/main/java/it/angrybear/yagl/items/ItemImpl.java b/item/base/src/main/java/it/angrybear/yagl/items/ItemImpl.java index 9a256eb5..c8a464a4 100644 --- a/item/base/src/main/java/it/angrybear/yagl/items/ItemImpl.java +++ b/item/base/src/main/java/it/angrybear/yagl/items/ItemImpl.java @@ -105,8 +105,8 @@ public boolean isSimilar(final @Nullable Item item, final ItemField @NotNull ... .noneMatch(f2 -> f.getName().equalsIgnoreCase(f2.name() .replace("_", "")))) .allMatch(f -> { - Object obj1 = ReflectionUtils.get(f, this); - Object obj2 = ReflectionUtils.get(f, item); + Object obj1 = ReflectionUtils.getOrThrow(f, this); + Object obj2 = ReflectionUtils.getOrThrow(f, item); return Objects.equals(obj1, obj2); }); } diff --git a/item/serializer/src/test/java/it/angrybear/yagl/parsers/RecipeParserTest.java b/item/serializer/src/test/java/it/angrybear/yagl/parsers/RecipeParserTest.java index 8cb54834..57d056f1 100644 --- a/item/serializer/src/test/java/it/angrybear/yagl/parsers/RecipeParserTest.java +++ b/item/serializer/src/test/java/it/angrybear/yagl/parsers/RecipeParserTest.java @@ -69,8 +69,8 @@ void testRecipe(Recipe recipe) throws IOException { Recipe recipe2 = configuration.get(path, Recipe.class); for (final Field field : recipe.getClass().getDeclaredFields()) { - Object obj1 = ReflectionUtils.get(field, recipe); - Object obj2 = ReflectionUtils.get(field, recipe2); + Object obj1 = ReflectionUtils.getOrThrow(field, recipe); + Object obj2 = ReflectionUtils.getOrThrow(field, recipe2); assertEquals(obj1, obj2); } } diff --git a/wrappers/bukkit/src/test/java/it/angrybear/yagl/WrappersAdapterTest.java b/wrappers/bukkit/src/test/java/it/angrybear/yagl/WrappersAdapterTest.java index 9fe20aa3..d0a36133 100644 --- a/wrappers/bukkit/src/test/java/it/angrybear/yagl/WrappersAdapterTest.java +++ b/wrappers/bukkit/src/test/java/it/angrybear/yagl/WrappersAdapterTest.java @@ -287,7 +287,7 @@ private static org.bukkit.potion.PotionEffect[] getPotionEffects() { List potionEffects = new ArrayList<>(); for (Field field : PotionEffectType.class.getDeclaredFields()) if (field.getType().equals(PotionEffectType.class)) { - PotionEffectType type = ReflectionUtils.get(field, PotionEffectType.class); + PotionEffectType type = ReflectionUtils.getOrThrow(field, PotionEffectType.class); potionEffects.add(new MockPotionEffect(type.getId(), field.getName())); } // Register potion effects @@ -310,7 +310,7 @@ private static org.bukkit.enchantments.Enchantment[] getEnchantments() { List enchantments = new ArrayList<>(); for (Field field : org.bukkit.enchantments.Enchantment.class.getDeclaredFields()) if (field.getType().equals(org.bukkit.enchantments.Enchantment.class)) { - org.bukkit.enchantments.Enchantment enchant = ReflectionUtils.get(field, org.bukkit.enchantments.Enchantment.class); + org.bukkit.enchantments.Enchantment enchant = ReflectionUtils.getOrThrow(field, org.bukkit.enchantments.Enchantment.class); enchantments.add(new MockEnchantment(enchant.getKey())); } // Register enchantments diff --git a/wrappers/serializer/src/test/java/it/angrybear/yagl/particles/ParticleOptionParserTest.java b/wrappers/serializer/src/test/java/it/angrybear/yagl/particles/ParticleOptionParserTest.java index a890eaf2..b19348eb 100644 --- a/wrappers/serializer/src/test/java/it/angrybear/yagl/particles/ParticleOptionParserTest.java +++ b/wrappers/serializer/src/test/java/it/angrybear/yagl/particles/ParticleOptionParserTest.java @@ -59,8 +59,8 @@ void testOptions(ParticleOption expected) throws IOException { Field[] fields = expected.getClass().getDeclaredFields(); for (Field field : fields) { - Object obj1 = ReflectionUtils.get(field, expected); - Object obj2 = ReflectionUtils.get(field, actual); + Object obj1 = ReflectionUtils.getOrThrow(field, expected); + Object obj2 = ReflectionUtils.getOrThrow(field, actual); assertEquals(obj1.getClass(), obj2.getClass()); assertEquals(obj1, obj2); } diff --git a/wrappers/serializer/src/test/java/it/angrybear/yagl/particles/ParticleParserTest.java b/wrappers/serializer/src/test/java/it/angrybear/yagl/particles/ParticleParserTest.java index f4cd942f..31d5c0a6 100644 --- a/wrappers/serializer/src/test/java/it/angrybear/yagl/particles/ParticleParserTest.java +++ b/wrappers/serializer/src/test/java/it/angrybear/yagl/particles/ParticleParserTest.java @@ -79,8 +79,8 @@ void testTypes(AParticleType type) throws IOException { Field[] fields = expected.getClass().getDeclaredFields(); for (Field field : fields) { - Object obj1 = ReflectionUtils.get(field, expected); - Object obj2 = ReflectionUtils.get(field, actual); + Object obj1 = ReflectionUtils.getOrThrow(field, expected); + Object obj2 = ReflectionUtils.getOrThrow(field, actual); if (obj1 == null) assertNull(obj2); else { assertEquals(obj1.getClass(), obj2.getClass()); From e461c4937e8f7797ec6fee56193506f33e4f12d8 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 11:26:08 +0200 Subject: [PATCH 116/204] Added tests for IllegalArgumentException thrown during #copy invocation --- .../angrybear/yagl/utils/ObjectUtilsTest.java | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/common/base/src/test/java/it/angrybear/yagl/utils/ObjectUtilsTest.java b/common/base/src/test/java/it/angrybear/yagl/utils/ObjectUtilsTest.java index 8226c027..95f0ddcb 100644 --- a/common/base/src/test/java/it/angrybear/yagl/utils/ObjectUtilsTest.java +++ b/common/base/src/test/java/it/angrybear/yagl/utils/ObjectUtilsTest.java @@ -38,12 +38,23 @@ void testCopyOfData() { assertNotEquals(c1.copiable, c2.copiable); } + @Test + void testCopyThrowsIllegalArgument() { + Throwable exception = assertThrowsExactly(IllegalArgumentException.class, () -> + ObjectUtils.copy(new GeneralCopyException())); + assertEquals("Everything good", exception.getMessage()); + } + private static class GeneralCopy { List list = Arrays.asList("hello", "world"); String[] array = new String[]{"hello", "world"}; GeneralCopiable copiable = new GeneralCopiable(); } + private static class GeneralCopyException { + GeneralCopiableException copiable = new GeneralCopiableException(); + } + private static class GeneralCopiable { public GeneralCopiable copy() { @@ -51,6 +62,13 @@ public GeneralCopiable copy() { } } + private static class GeneralCopiableException { + + public GeneralCopiable copy() { + throw new IllegalArgumentException("Everything good"); + } + } + private static class CopyIterableImpl { } private static class CopyIterable implements Iterable { From 66543ba31a96c797f7860ba20235515c4ab07171 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 11:27:17 +0200 Subject: [PATCH 117/204] Refactored code --- .../src/main/java/it/angrybear/yagl/Metadatable.java | 9 ++------- 1 file changed, 2 insertions(+), 7 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java b/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java index be0efac8..01de39a6 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java +++ b/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java @@ -130,13 +130,8 @@ default T apply(final T object) { else if (!ReflectionUtils.isPrimitiveOrWrapper(object.getClass())) { final Refl refl = new Refl<>(object); for (Field field : refl.getNonStaticFields()) - ReflectionUtils.setAccessible(field).ifPresent(f -> { - try { - refl.setFieldObject(f, apply(f.get(object))); - } catch (IllegalAccessException e) { - throw new RuntimeException(e); - } - }); + ReflectionUtils.setAccessible(field).ifPresent(f -> + refl.setFieldObject(f, apply(f.get(object)))); } return object; } From 112687463c730977b5384d19368d5215e16c29ec Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Wed, 17 Apr 2024 11:30:05 +0200 Subject: [PATCH 118/204] Added tests for openGUIAction --- .../test/java/it/angrybear/yagl/GUIAdapterTest.java | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java b/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java index bcdf042d..654b4c85 100644 --- a/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java +++ b/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java @@ -1,5 +1,6 @@ package it.angrybear.yagl; +import it.angrybear.yagl.actions.GUIAction; import it.angrybear.yagl.contents.GUIContent; import it.angrybear.yagl.contents.ItemGUIContent; import it.angrybear.yagl.guis.GUI; @@ -136,6 +137,15 @@ void testCloseGUIForOfflinePlayer() { assertThrowsExactly(PlayerOfflineException.class, this::closeGUI); } + @Test + void testOpenGUIAction() { + GUI gui = GUI.newGUI(9); + GUIAction openAction = mock(GUIAction.class); + gui.onOpenGUI(openAction); + openGUI(gui); + verify(openAction).execute(GUIManager.getViewer(this.player), gui); + } + private void openGUI(GUI gui) { GUITestUtils.mockPlugin(p -> gui.open(GUIManager.getViewer(this.player))); } From 1fe5e345d3a631d75a5f685b0579ed5acb974cda Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 14:42:26 +0200 Subject: [PATCH 119/204] Extended constructors visibility --- .../it/angrybear/yagl/guis/PageableGUI.java | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java index a8ac2caf..15d5ed54 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java @@ -25,15 +25,28 @@ public class PageableGUI extends FieldEquable implements Iterable, Metadata private final Tuple previousPage = new Tuple<>(); private final Tuple nextPage = new Tuple<>(); - private PageableGUI() { + /** + * Instantiates a new Pageable gui. + */ + PageableGUI() { this.templateGUI = null; } - private PageableGUI(final int size) { + /** + * Instantiates a new Pageable gui. + * + * @param size the size + */ + PageableGUI(final int size) { this.templateGUI = GUI.newGUI(size); } - private PageableGUI(final @NotNull GUIType type) { + /** + * Instantiates a new Pageable gui. + * + * @param type the type + */ + PageableGUI(final @NotNull GUIType type) { this.templateGUI = GUI.newGUI(type); } From 534ed76a0efe17095fb0e8209483e9f8c3d17b7f Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 14:45:09 +0200 Subject: [PATCH 120/204] Extracted prepareOpenGUI --- .../java/it/angrybear/yagl/guis/PageableGUI.java | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java index 15d5ed54..0541bf04 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java @@ -189,6 +189,17 @@ public void open(final @NotNull Viewer viewer) { * @param page the page */ public void open(final @NotNull Viewer viewer, final int page) { + GUI gui = prepareOpenGUI(page); + gui.open(viewer); + } + + /** + * Prepares the {@link GUI} at the given page for {@link #open(Viewer, int)}. + * + * @param page the page + * @return the gui + */ + @NotNull GUI prepareOpenGUI(int page) { GUI gui = getPage(page).copy().copyFrom(this, false) .setVariable("page", String.valueOf(page + 1)) .setVariable("previous-page", String.valueOf(page)) @@ -198,7 +209,7 @@ public void open(final @NotNull Viewer viewer, final int page) { gui.setContents(s, p.copy().onClickItem((v, g, i) -> open(v, page - 1)))); if (page + 1 < pages()) this.nextPage.ifPresent((s, p) -> gui.setContents(s, p.copy().onClickItem((v, g, i) -> open(v, page + 1)))); - gui.open(viewer); + return gui; } @Override From b639988790e95417a874ce984e8f8aea3d9a277c Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 17:01:43 +0200 Subject: [PATCH 121/204] Added emptySlots method --- .../main/java/it/angrybear/yagl/guis/GUI.java | 12 ++++++++++++ .../java/it/angrybear/yagl/guis/GUITest.java | 17 +++++++++++++---- 2 files changed, 25 insertions(+), 4 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/GUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/GUI.java index aa98a5e8..86dcdb80 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/GUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/GUI.java @@ -1163,6 +1163,18 @@ default int southEast() { */ int columns(); + /** + * Counts the empty slots of the current GUI. + * + * @return the slots + */ + default Set emptySlots() { + Set slots = new HashSet<>(); + for (int i = 0; i < size(); i++) + if (getContents(i).isEmpty()) slots.add(i); + return slots; + } + /** * Removes all the contents in this GUI. * diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/GUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/GUITest.java index 206ceabc..e7929177 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/GUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/GUITest.java @@ -5,14 +5,12 @@ import it.angrybear.yagl.items.Item; import it.fulminazzo.fulmicollection.objects.Refl; import org.jetbrains.annotations.NotNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.params.ParameterizedTest; import org.junit.jupiter.params.provider.MethodSource; import org.junit.jupiter.params.provider.ValueSource; -import java.util.Collections; -import java.util.HashMap; -import java.util.List; -import java.util.Map; +import java.util.*; import java.util.function.Predicate; import static org.junit.jupiter.api.Assertions.*; @@ -268,4 +266,15 @@ void testSetCornersMethods(String methodName) { assertEquals(guiContent, gui.getContents(slot).get(0)); } + @Test + void testEmptySlots() { + GUI gui = GUI.newGUI(54); + gui.setContents(1, Item.newItem("Stone")); + + Set slots = gui.emptySlots(); + for (int i = 0; i < gui.size(); i++) + if (i == 1) assertFalse(slots.contains(i), String.format("Slots should not contain '%s'", i)); + else assertTrue(slots.contains(i), String.format("Slots should contain '%s'", i)); + } + } \ No newline at end of file From 0f3c755dfea1c00431ebbcbb5bd12ee0145b1373 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 18:34:56 +0200 Subject: [PATCH 122/204] Created DataGUI class --- .../java/it/angrybear/yagl/guis/DataGUI.java | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) create mode 100644 gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java new file mode 100644 index 00000000..4881355e --- /dev/null +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -0,0 +1,18 @@ +package it.angrybear.yagl.guis; + +import org.jetbrains.annotations.NotNull; + +public class DataGUI extends PageableGUI { + + DataGUI() { + + } + + DataGUI(int size) { + super(size); + } + + DataGUI(@NotNull GUIType type) { + super(type); + } +} From ab6103bb68e4354d98c21eecac08508805c3c9d1 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 18:40:55 +0200 Subject: [PATCH 123/204] Added data field with related methods --- .../java/it/angrybear/yagl/guis/DataGUI.java | 118 +++++++++++++++++- 1 file changed, 115 insertions(+), 3 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 4881355e..a32ec447 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -2,17 +2,129 @@ import org.jetbrains.annotations.NotNull; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.Collection; +import java.util.List; +import java.util.function.Predicate; + +/** + * An implementation of {@link PageableGUI} that allows data to be automatically displayed in a multi-paged format. + * + * @param the type of the data + */ public class DataGUI extends PageableGUI { + private final List data; + /** + * Instantiates a new Data gui. + */ DataGUI() { - + this.data = new ArrayList<>(); } - DataGUI(int size) { + /** + * Instantiates a new Data gui. + * + * @param size the size + * @param data the data + */ + DataGUI(int size, List data) { super(size); + this.data = data; } - DataGUI(@NotNull GUIType type) { + /** + * Instantiates a new Data gui. + * + * @param type the type + * @param data the data + */ + DataGUI(@NotNull GUIType type, List data) { super(type); + this.data = data; + } + + /** + * Adds the given data. + * + * @param data the data + * @return this gui + */ + public DataGUI addData(final T @NotNull ... data) { + return addData(Arrays.asList(data)); + } + + /** + * Adds the given data. + * + * @param data the data + * @return this gui + */ + public DataGUI addData(final @NotNull Collection data) { + this.data.addAll(data); + return this; + } + + /** + * Clears the current data and sets the given data. + * + * @param data the data + * @return the data + */ + public DataGUI setData(final T @NotNull ... data) { + return setData(Arrays.asList(data)); + } + + /** + * Clears the current data and sets the given data. + * + * @param data the data + * @return the data + */ + public DataGUI setData(final @NotNull Collection data) { + return clearData().addData(data); + } + + /** + * Removes the data equal to any of the given data. + * + * @param data the data + * @return this gui + */ + public DataGUI removeData(final T @NotNull ... data) { + return removeData(Arrays.asList(data)); + } + + /** + * Removes the data equal to any of the given data. + * + * @param data the data + * @return this gui + */ + public DataGUI removeData(final @NotNull Collection data) { + return removeData(t -> t.equals(data)); + } + + /** + * Removes the data that match the given {@link Predicate} function. + * + * @param function the function + * @return this gui + */ + public DataGUI removeData(final @NotNull Predicate function) { + this.data.removeIf(function); + return this; + } + + /** + * Removes all the data. + * + * @return this gui + */ + public DataGUI clearData() { + this.data.clear(); + return this; } + } From dc1d1a46c4e232183c0b1cddeebc3ef455ff2e06 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 18:42:08 +0200 Subject: [PATCH 124/204] Added dataConverter field --- .../src/main/java/it/angrybear/yagl/guis/DataGUI.java | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index a32ec447..4a2ce204 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -1,11 +1,13 @@ package it.angrybear.yagl.guis; +import it.angrybear.yagl.contents.GUIContent; import org.jetbrains.annotations.NotNull; import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; import java.util.List; +import java.util.function.Function; import java.util.function.Predicate; /** @@ -15,12 +17,14 @@ */ public class DataGUI extends PageableGUI { private final List data; + private final Function dataConverter; /** * Instantiates a new Data gui. */ DataGUI() { this.data = new ArrayList<>(); + this.dataConverter = null; } /** @@ -29,9 +33,10 @@ public class DataGUI extends PageableGUI { * @param size the size * @param data the data */ - DataGUI(int size, List data) { + DataGUI(int size, List data, Function dataConverter) { super(size); this.data = data; + this.dataConverter = dataConverter; } /** @@ -40,9 +45,10 @@ public class DataGUI extends PageableGUI { * @param type the type * @param data the data */ - DataGUI(@NotNull GUIType type, List data) { + DataGUI(@NotNull GUIType type, List data, Function dataConverter) { super(type); this.data = data; + this.dataConverter = dataConverter; } /** From 847abc9b4b17486fc679bd8c4b0d97073dde933f Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 18:42:24 +0200 Subject: [PATCH 125/204] Temporarily removed empty constructor --- .../src/main/java/it/angrybear/yagl/guis/DataGUI.java | 9 --------- 1 file changed, 9 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 4a2ce204..709944ff 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -3,7 +3,6 @@ import it.angrybear.yagl.contents.GUIContent; import org.jetbrains.annotations.NotNull; -import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; import java.util.List; @@ -19,14 +18,6 @@ public class DataGUI extends PageableGUI { private final List data; private final Function dataConverter; - /** - * Instantiates a new Data gui. - */ - DataGUI() { - this.data = new ArrayList<>(); - this.dataConverter = null; - } - /** * Instantiates a new Data gui. * From 154d60efe60d534d2b146df34c3b664b57338165 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 18:48:36 +0200 Subject: [PATCH 126/204] Overridden getPage, setPages and pages methods --- .../java/it/angrybear/yagl/guis/DataGUI.java | 41 ++++++++++++++++++- 1 file changed, 40 insertions(+), 1 deletion(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 709944ff..181c90d8 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -15,6 +15,8 @@ * @param the type of the data */ public class DataGUI extends PageableGUI { + private static final String ERROR_MESSAGE = "Pages are dynamically calculated when opening this GUI. They cannot be singly edited"; + private final List data; private final Function dataConverter; @@ -123,5 +125,42 @@ public DataGUI clearData() { this.data.clear(); return this; } - + + /** + * Gets the {@link GUI} page from the given index. + * The index starts from 0. + * + * @param page the page + * @deprecated In {@link DataGUI}s pages are not pre-defined, but rather calculated upon opening. + * @return the corresponding {@link GUI} page + */ + @Override + @Deprecated + public GUI getPage(int page) { + throw new IllegalStateException(ERROR_MESSAGE); + } + + /** + * Sets pages. + * + * @param pages the pages + * @deprecated In {@link DataGUI}s pages are not pre-defined, but rather calculated upon opening. + * @return this gui + */ + @Override + public PageableGUI setPages(int pages) { + throw new IllegalStateException(ERROR_MESSAGE); + } + + /** + * Gets the number of pages based on the amount of data provided. + * + * @return the pages + */ + @Override + public int pages() { + double pages = (double) this.data.size() / emptySlots().size(); + return (int) Math.ceil(pages); + } + } From 88805f4a878f0f7b7fbabe60fd4e60408f1cefed Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 18:54:51 +0200 Subject: [PATCH 127/204] Added constructor methods --- .../java/it/angrybear/yagl/guis/DataGUI.java | 99 +++++++++++++++++-- 1 file changed, 91 insertions(+), 8 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 181c90d8..34a6582d 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -5,6 +5,7 @@ import java.util.Arrays; import java.util.Collection; +import java.util.LinkedList; import java.util.List; import java.util.function.Function; import java.util.function.Predicate; @@ -23,24 +24,24 @@ public class DataGUI extends PageableGUI { /** * Instantiates a new Data gui. * - * @param size the size - * @param data the data + * @param size the size + * @param dataConverter the data converter */ - DataGUI(int size, List data, Function dataConverter) { + DataGUI(final int size, final @NotNull Function dataConverter) { super(size); - this.data = data; + this.data = new LinkedList<>(); this.dataConverter = dataConverter; } /** * Instantiates a new Data gui. * - * @param type the type - * @param data the data + * @param type the type + * @param dataConverter the data converter */ - DataGUI(@NotNull GUIType type, List data, Function dataConverter) { + DataGUI(final @NotNull GUIType type, final @NotNull Function dataConverter) { super(type); - this.data = data; + this.data = new LinkedList<>(); this.dataConverter = dataConverter; } @@ -163,4 +164,86 @@ public int pages() { return (int) Math.ceil(pages); } + /** + * Creates a new {@link DataGUI} with the given size and converter. + * + * @param the type of the data + * @param size the size + * @param dataConverter the data converter + * @return the data gui + */ + public static DataGUI newGUI(final int size, final @NotNull Function dataConverter) { + return new DataGUI<>(size, dataConverter); + } + + /** + * Creates a new {@link DataGUI} with the given size, converter and data. + * + * @param the type of the data + * @param size the size + * @param dataConverter the data converter + * @param data the data + * @return the data gui + */ + @SafeVarargs + public static DataGUI newGUI(final int size, final @NotNull Function dataConverter, + final T @NotNull ... data) { + return new DataGUI<>(size, dataConverter).setData(data); + } + + /** + * Creates a new {@link DataGUI} with the given size, converter and data. + * + * @param the type of the data + * @param size the size + * @param dataConverter the data converter + * @param data the data + * @return the data gui + */ + public static DataGUI newGUI(final int size, final @NotNull Function dataConverter, + final @NotNull Collection data) { + return new DataGUI<>(size, dataConverter).setData(data); + } + + /** + * Creates a new {@link DataGUI} with the given type and converter. + * + * @param the type of the data + * @param type the type + * @param dataConverter the data converter + * @return the data gui + */ + public static DataGUI newGUI(final @NotNull GUIType type, final @NotNull Function dataConverter) { + return new DataGUI<>(type, dataConverter); + } + + /** + * Creates a new {@link DataGUI} with the given type, converter and data. + * + * @param the type of the data + * @param type the type + * @param dataConverter the data converter + * @param data the data + * @return the data gui + */ + @SafeVarargs + public static DataGUI newGUI(final @NotNull GUIType type, final @NotNull Function dataConverter, + final T @NotNull ... data) { + return new DataGUI<>(type, dataConverter).setData(data); + } + + /** + * Creates a new {@link DataGUI} with the given type, converter and data. + * + * @param the type of the data + * @param type the type + * @param dataConverter the data converter + * @param data the data + * @return the data gui + */ + public static DataGUI newGUI(final @NotNull GUIType type, final @NotNull Function dataConverter, + final @NotNull Collection data) { + return new DataGUI<>(type, dataConverter).setData(data); + } + } From c20a8ad4a89b424e826bc3fbef2d68720d2029ea Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 18:57:39 +0200 Subject: [PATCH 128/204] Added test suite for DataGUI --- .../it/angrybear/yagl/guis/DataGUITest.java | 32 +++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java diff --git a/gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java new file mode 100644 index 00000000..341e01eb --- /dev/null +++ b/gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -0,0 +1,32 @@ +package it.angrybear.yagl.guis; + +import it.angrybear.yagl.contents.ItemGUIContent; +import it.angrybear.yagl.items.Item; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.MethodSource; + +import static org.junit.jupiter.api.Assertions.assertEquals; + +class DataGUITest { + + private static Object[][] pagesTest() { + return new Object[][]{ + new Object[]{0, 27, 1}, + new Object[]{0, 54, 2}, + new Object[]{9, 54, 3}, + new Object[]{26, 54, 54}, + new Object[]{14, 198, 16}, + }; + } + + @ParameterizedTest + @MethodSource("pagesTest") + void testPagesMethod(int contents, int data, int expected) { + DataGUI dataGUI = DataGUI.newGUI(27, s -> ItemGUIContent.newInstance()); + for (int i = 0; i < data; i++) dataGUI.addData(i); + for (int i = 0; i < contents; i++) dataGUI.addContent(Item.newItem("stone")); + + int pages = dataGUI.pages(); + assertEquals(expected, pages); + } +} \ No newline at end of file From a6d8960d0abfecec1f6bd5c31434afd97f439ce4 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:13:14 +0200 Subject: [PATCH 129/204] Added fillContents method --- .../src/main/java/it/angrybear/yagl/guis/DataGUI.java | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 34a6582d..9c6afa0c 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -127,6 +127,16 @@ public DataGUI clearData() { return this; } + private @NotNull GUI fillContents(final @NotNull GUI gui, final int page) { + int emptySlots = gui.emptySlots().size(); + int min = emptySlots * page; + int max = emptySlots * (page + 1); + int size = this.data.size(); + for (int i = Math.min(min, size); i < Math.min(max, size); i++) + gui.addContent(this.dataConverter.apply(this.data.get(i))); + return gui; + } + /** * Gets the {@link GUI} page from the given index. * The index starts from 0. From 89b8c21bf655153c3a99e100f9aba454e2f9546a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:18:09 +0200 Subject: [PATCH 130/204] Added tests for fillContents method --- .../it/angrybear/yagl/guis/DataGUITest.java | 35 ++++++++++++++++++- 1 file changed, 34 insertions(+), 1 deletion(-) diff --git a/gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 341e01eb..5a1fe681 100644 --- a/gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -1,11 +1,16 @@ package it.angrybear.yagl.guis; +import it.angrybear.yagl.contents.GUIContent; import it.angrybear.yagl.contents.ItemGUIContent; import it.angrybear.yagl.items.Item; +import it.fulminazzo.fulmicollection.objects.Refl; +import org.jetbrains.annotations.NotNull; import org.junit.jupiter.params.ParameterizedTest; import org.junit.jupiter.params.provider.MethodSource; -import static org.junit.jupiter.api.Assertions.assertEquals; +import java.util.List; + +import static org.junit.jupiter.api.Assertions.*; class DataGUITest { @@ -19,6 +24,34 @@ private static Object[][] pagesTest() { }; } + @ParameterizedTest + @MethodSource("pagesTest") + void testFillContentsMethod(int contents, int data, int pages) { + GUIContent convertedContent = ItemGUIContent.newInstance("grass"); + DataGUI dataGUI = DataGUI.newGUI(27, s -> convertedContent); + Refl guiRefl = new Refl<>(dataGUI); + for (int i = 0; i < data; i++) dataGUI.addData(i); + @NotNull Item stone = Item.newItem("stone"); + for (int i = 0; i < contents; i++) dataGUI.addContent(stone); + + for (int p = 0; p < pages; p++) { + GUI gui = guiRefl.getFieldObject("templateGUI"); + assertNotNull(gui); + gui = guiRefl.invokeMethod("fillContents", gui.copy(), p); + assertNotNull(gui); + + for (int c = 0; c < dataGUI.size(); c++) { + if (gui.emptySlots().contains(c)) continue; + @NotNull List cs = gui.getContents(c); + assertFalse(cs.isEmpty(), String.format("Expected not empty at slot %s for page %s", c, p)); + GUIContent content = cs.get(0); + String message = String.format("Invalid material at slot %s for page %s", c, p); + if (c < contents) assertNotEquals(convertedContent, content, message); + else assertEquals(convertedContent, content, message); + } + } + } + @ParameterizedTest @MethodSource("pagesTest") void testPagesMethod(int contents, int data, int expected) { From d0ddadc0ac9256b7ed807430ec21c4ba4deba661 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:19:44 +0200 Subject: [PATCH 131/204] Reworked prepareOpenGUI method to accept GUI and page --- .../main/java/it/angrybear/yagl/guis/PageableGUI.java | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java index 0541bf04..c5189ca0 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java @@ -189,18 +189,18 @@ public void open(final @NotNull Viewer viewer) { * @param page the page */ public void open(final @NotNull Viewer viewer, final int page) { - GUI gui = prepareOpenGUI(page); - gui.open(viewer); + prepareOpenGUI(getPage(page), page).open(viewer); } /** * Prepares the {@link GUI} at the given page for {@link #open(Viewer, int)}. * - * @param page the page + * @param gui the gui + * @param page the page * @return the gui */ - @NotNull GUI prepareOpenGUI(int page) { - GUI gui = getPage(page).copy().copyFrom(this, false) + @NotNull GUI prepareOpenGUI(final @NotNull GUI gui, final int page) { + gui.copy().copyFrom(this, false) .setVariable("page", String.valueOf(page + 1)) .setVariable("previous-page", String.valueOf(page)) .setVariable("next-page", String.valueOf(page + 2)) From 1676d9e0b0d2f556649a24436bfcbb73949400ef Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:20:46 +0200 Subject: [PATCH 132/204] Extended templateGUI visibility --- .../src/main/java/it/angrybear/yagl/guis/PageableGUI.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java index c5189ca0..59a29fb1 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java @@ -18,7 +18,7 @@ * An implementation of {@link GUI} that allows multiple GUI pages to be added. */ public class PageableGUI extends FieldEquable implements Iterable, Metadatable, GUI { - private final GUI templateGUI; + protected final GUI templateGUI; private final List pages = new LinkedList<>(); private final Map variables = new HashMap<>(); @@ -199,7 +199,7 @@ public void open(final @NotNull Viewer viewer, final int page) { * @param page the page * @return the gui */ - @NotNull GUI prepareOpenGUI(final @NotNull GUI gui, final int page) { + protected @NotNull GUI prepareOpenGUI(final @NotNull GUI gui, final int page) { gui.copy().copyFrom(this, false) .setVariable("page", String.valueOf(page + 1)) .setVariable("previous-page", String.valueOf(page)) From 2b15c724bce8a36c5f970a2e1b5e97c9b1883a7a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:21:47 +0200 Subject: [PATCH 133/204] Reworked open method to use dynamic system --- .../src/main/java/it/angrybear/yagl/guis/DataGUI.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 9c6afa0c..686bdb98 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -1,6 +1,7 @@ package it.angrybear.yagl.guis; import it.angrybear.yagl.contents.GUIContent; +import it.angrybear.yagl.viewers.Viewer; import org.jetbrains.annotations.NotNull; import java.util.Arrays; @@ -127,6 +128,13 @@ public DataGUI clearData() { return this; } + @Override + public void open(@NotNull Viewer viewer, int page) { + GUI templateGUI = this.templateGUI; + if (templateGUI == null) throw new IllegalStateException("templateGUI did not load correctly"); + fillContents(prepareOpenGUI(templateGUI, page), page).open(viewer); + } + private @NotNull GUI fillContents(final @NotNull GUI gui, final int page) { int emptySlots = gui.emptySlots().size(); int min = emptySlots * page; From e464595ed55062a58ecdde9dfed331fa60f0c4c3 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:31:40 +0200 Subject: [PATCH 134/204] Created OpenDataGUI command --- .../resources/commands/OpenDataGUI.groovy | 80 +++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 demo/src/main/resources/commands/OpenDataGUI.groovy diff --git a/demo/src/main/resources/commands/OpenDataGUI.groovy b/demo/src/main/resources/commands/OpenDataGUI.groovy new file mode 100644 index 00000000..b451c72f --- /dev/null +++ b/demo/src/main/resources/commands/OpenDataGUI.groovy @@ -0,0 +1,80 @@ +import it.angrybear.yagl.GUIManager +import it.angrybear.yagl.contents.GUIContent +import it.angrybear.yagl.contents.ItemGUIContent +import it.angrybear.yagl.guis.DataGUI +import it.angrybear.yagl.guis.GUIType +import it.angrybear.yagl.guis.PageableGUI +import it.angrybear.yagl.items.BukkitItem +import it.angrybear.yagl.utils.EnumUtils +import org.bukkit.Material +import org.bukkit.entity.Player + +import java.util.function.Function + +def run = { sender, label, args -> + if (sender instanceof Player) + try { + def data = [ + 'James', 'Mary', 'Robert', 'Patricia', 'John', 'Jennifer', 'Michael', + 'Linda', 'David', 'Elizabeth', 'William', 'Barbara', 'Richard', 'Susan', + 'Joseph', 'Jessica', 'Thomas', 'Sarah', 'Christopher', 'Karen', 'Charles', + 'Lisa', 'Daniel', 'Nancy', 'Matthew', 'Betty', 'Anthony', 'Sandra', 'Mark', + 'Margaret', 'Donald', 'Ashley', 'Steven', 'Kimberly', 'Andrew', 'Emily', 'Paul', + 'Donna', 'Joshua', 'Michelle', 'Kenneth', 'Carol', 'Kevin', 'Amanda', 'Brian', + 'Melissa', 'George', 'Deborah', 'Timothy', 'Stephanie', 'Ronald', 'Dorothy', + 'Jason', 'Rebecca', 'Edward', 'Sharon', 'Jeffrey', 'Laura', 'Ryan', 'Cynthia', + 'Jacob', 'Amy', 'Gary', 'Kathleen', 'Nicholas', 'Angela', 'Eric', 'Shirley', + 'Jonathan', 'Brenda', 'Stephen', 'Emma', 'Larry', 'Anna', 'Justin', 'Pamela', + 'Scott', 'Nicole', 'Brandon', 'Samantha', 'Benjamin', 'Katherine', 'Samuel', + 'Christine', 'Gregory', 'Helen', 'Alexander', 'Debra', 'Patrick', 'Rachel', + 'Frank', 'Carolyn', 'Raymond', 'Janet', 'Jack', 'Maria', 'Dennis', 'Catherine', + 'Jerry', 'Heather', 'Tyler', 'Diane', 'Aaron', 'Olivia', 'Jose', 'Julie', 'Adam', + 'Joyce', 'Nathan', 'Victoria', 'Henry', 'Ruth', 'Zachary', 'Virginia', 'Douglas', + 'Lauren', 'Peter', 'Kelly', 'Kyle', 'Christina', 'Noah', 'Joan', 'Ethan', 'Evelyn', + 'Jeremy', 'Judith', 'Walter', 'Andrea', 'Christian', 'Hannah', 'Keith', 'Megan', + 'Roger', 'Cheryl', 'Terry', 'Jacqueline', 'Austin', 'Martha', 'Sean', 'Madison', + 'Gerald', 'Teresa', 'Carl', 'Gloria', 'Harold', 'Sara', 'Dylan', 'Janice', 'Arthur', + 'Ann', 'Lawrence', 'Kathryn', 'Jordan', 'Abigail', 'Jesse', 'Sophia', 'Bryan', 'Frances', + 'Billy', 'Jean', 'Bruce', 'Alice', 'Gabriel', 'Judy', 'Joe', 'Isabella', 'Logan', 'Julia', + 'Alan', 'Grace', 'Juan', 'Amber', 'Albert', 'Denise', 'Willie', 'Danielle', 'Elijah', + 'Marilyn', 'Wayne', 'Beverly', 'Randy', 'Charlotte', 'Vincent', 'Natalie', 'Mason', + 'Theresa', 'Roy', 'Diana', 'Ralph', 'Brittany', 'Bobby', 'Doris', 'Russell', 'Kayla', + 'Bradley', 'Alexis', 'Philip', 'Lori', 'Eugene', 'Marie' + ] + Function converter = s -> ItemGUIContent.newInstance(Material.PLAYER_HEAD.name()) + .setDisplayName("&e${s}'s head") + .setLore("&7This head belongs to &e${s}&7.", + '&7Make sure to give it back to them', + '&7once you are done playing with it!') + PageableGUI gui + try { + gui = DataGUI.newGUI(EnumUtils.valueOf(GUIType, args[0]), converter, data) + } catch (IllegalArgumentException ignored) { + gui = DataGUI.newGUI(Integer.valueOf(args[0]), converter, data) + } catch (IndexOutOfBoundsException ignored) { + sender.sendMessage("Usage: /opendatagui ") + return + } + def size = gui.size() + def middle = (int) Math.min(size / 2, 9 / 2) + if (size > 1) { + size -= 1 + gui.setContents(size - middle, BukkitItem.newItem(Material.OBSIDIAN).setDisplayName("&7Page: &e")) + .setPreviousPage(size - middle * 2, BukkitItem.newItem(Material.REDSTONE_BLOCK) + .setDisplayName("&7Go to page &e")) + .setNextPage(size, BukkitItem.newItem(Material.EMERALD_BLOCK) + .setDisplayName("&7Go to page &e")) + } + + gui.setTitle("Page #") + .onClickOutside((v, g) -> v.sendMessage('Please only click inside me!')) + .onOpenGUI((v, g) -> v.sendMessage(g.apply('Opening page '))) + .onCloseGUI((v, g) -> v.sendMessage('Goodbye!')) + .open(GUIManager.getViewer(sender)) + } catch (NumberFormatException ignored) { + + } catch (Exception e) { + sender.sendMessage(e.getMessage()) + } + else sender.sendMessage('Console cannot execute this command!') +} \ No newline at end of file From d46e443d5e132f12463da7f94b3adc425a4442e8 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:33:12 +0200 Subject: [PATCH 135/204] Fixed open method --- gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 686bdb98..5501e7a5 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -132,7 +132,7 @@ public DataGUI clearData() { public void open(@NotNull Viewer viewer, int page) { GUI templateGUI = this.templateGUI; if (templateGUI == null) throw new IllegalStateException("templateGUI did not load correctly"); - fillContents(prepareOpenGUI(templateGUI, page), page).open(viewer); + prepareOpenGUI(fillContents(templateGUI, page), page).open(viewer); } private @NotNull GUI fillContents(final @NotNull GUI gui, final int page) { From 03c8adc8e530ac63fd438244f0ab38408b5c80f6 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:35:29 +0200 Subject: [PATCH 136/204] Moved to appropriate package --- .../src/test/java/it/angrybear/yagl/guis/DataGUITest.java | 6 ++++++ 1 file changed, 6 insertions(+) rename gui/{serializer => base}/src/test/java/it/angrybear/yagl/guis/DataGUITest.java (97%) diff --git a/gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java similarity index 97% rename from gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java rename to gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 5a1fe681..33644a8e 100644 --- a/gui/serializer/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -5,6 +5,7 @@ import it.angrybear.yagl.items.Item; import it.fulminazzo.fulmicollection.objects.Refl; import org.jetbrains.annotations.NotNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.params.ParameterizedTest; import org.junit.jupiter.params.provider.MethodSource; @@ -62,4 +63,9 @@ void testPagesMethod(int contents, int data, int expected) { int pages = dataGUI.pages(); assertEquals(expected, pages); } + + @Test + void testOpenPage() { + + } } \ No newline at end of file From 9d28d649e889352f7d1b418d93975e685b9eb36c Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:37:09 +0200 Subject: [PATCH 137/204] Fixed many visibility issues --- .../java/it/angrybear/yagl/guis/PageableGUITest.java | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java index a1312e2c..0fa379c4 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java @@ -63,7 +63,8 @@ void testOpenPage() { final MockViewer viewer = new MockViewer(UUID.randomUUID(), "Steve"); try (MockedStatic clazz = mockStatic(ReflectionUtils.class, CALLS_REAL_METHODS)) { - clazz.when(() -> ReflectionUtils.getClass("it.angrybear.yagl.GUIAdapter")).thenReturn(MockGUIAdapter.class); + clazz.when(() -> ReflectionUtils.getClass("it.angrybear.yagl.GUIAdapter")) + .thenReturn(MockGUIAdapter.class); for (int i = 0; i < gui.pages(); i++) { gui.open(viewer, i); @@ -87,7 +88,7 @@ void testOpenPage() { } } - private GUI generateExpected(GUI gui, int index) { + static GUI generateExpected(GUI gui, int index) { GUI g = GUI.newGUI(9) .setContents(1, gui.getContents(1)) .setContents(4, Item.newItem("obsidian").setDisplayName("&7Page: &e")) @@ -232,7 +233,7 @@ private GUI setupGUI(GUI gui) { .onChangeGUI("command"); } - private static class MockViewer extends Viewer { + static class MockViewer extends Viewer { GUI openedGUI; protected MockViewer(UUID uniqueId, String name) { @@ -255,7 +256,7 @@ public boolean hasPermission(@NotNull String permission) { } } - private static class MockGUIAdapter { + static class MockGUIAdapter { public static void openGUI(GUI gui, MockViewer viewer) { viewer.openedGUI = gui; From e6eda7109a18969b5f7a4f5c06066efd3b38cab4 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:42:48 +0200 Subject: [PATCH 138/204] Added tests for DataGUI#open method --- .../it/angrybear/yagl/guis/DataGUITest.java | 41 +++++++++++++++++++ 1 file changed, 41 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 33644a8e..463e2f0f 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -1,17 +1,24 @@ package it.angrybear.yagl.guis; +import it.angrybear.yagl.actions.GUIItemAction; import it.angrybear.yagl.contents.GUIContent; import it.angrybear.yagl.contents.ItemGUIContent; import it.angrybear.yagl.items.Item; import it.fulminazzo.fulmicollection.objects.Refl; +import it.fulminazzo.fulmicollection.utils.ReflectionUtils; import org.jetbrains.annotations.NotNull; import org.junit.jupiter.api.Test; import org.junit.jupiter.params.ParameterizedTest; import org.junit.jupiter.params.provider.MethodSource; +import org.mockito.MockedStatic; import java.util.List; +import java.util.UUID; +import java.util.function.Function; import static org.junit.jupiter.api.Assertions.*; +import static org.mockito.Mockito.CALLS_REAL_METHODS; +import static org.mockito.Mockito.mockStatic; class DataGUITest { @@ -66,6 +73,40 @@ void testPagesMethod(int contents, int data, int expected) { @Test void testOpenPage() { + int[] slots = new int[]{1, 2, 3, 5, 6, 7}; + Double[] data = new Double[] { + 0.1, 0.2, 0.3, 0.5, 0.6, 0.7, + 1.1, 1.2, 1.3, 1.5, 1.6, 1.7, + 2.1, 2.2, 2.3, 2.5, 2.6, 2.7, + }; + Function cc = d -> ItemGUIContent.newInstance().setAmount((int) (d * 10)); + PageableGUI gui = DataGUI.newGUI(9, cc, data) + .setPreviousPage(0, Item.newItem("redstone_block") + .setDisplayName("&7Go to page &e")) + .setNextPage(8, Item.newItem("emerald_block") + .setDisplayName("&7Go to page &e")) + .setContents(4, Item.newItem("obsidian").setDisplayName("&7Page: &e")); + + final PageableGUITest.MockViewer viewer = new PageableGUITest.MockViewer(UUID.randomUUID(), "Steve"); + try (MockedStatic clazz = mockStatic(ReflectionUtils.class, CALLS_REAL_METHODS)) { + clazz.when(() -> ReflectionUtils.getClass("it.angrybear.yagl.GUIAdapter")) + .thenReturn(PageableGUITest.MockGUIAdapter.class); + + for (int i = 0; i < gui.pages(); i++) { + gui.open(viewer, i); + GUI expected = new Refl<>(gui).getFieldObject("templateGUI"); + assertNotNull(expected); + expected = PageableGUITest.generateExpected(expected.copy(), i); + + for (int s : slots) + expected.setContents(s, cc.apply(data[s + i * slots.length])); + GUI actual = viewer.openedGUI; + actual.getContents(0).forEach(e -> e.onClickItem((GUIItemAction) null)); + actual.getContents(8).forEach(e -> e.onClickItem((GUIItemAction) null)); + + assertEquals(expected, actual); + } + } } } \ No newline at end of file From baa8ea3335c0d2f21e12400ba557ba1fe19cd3c9 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:46:54 +0200 Subject: [PATCH 139/204] Fixed invalid slots for expected GUI --- .../src/test/java/it/angrybear/yagl/guis/DataGUITest.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 463e2f0f..086f2634 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -98,8 +98,8 @@ void testOpenPage() { assertNotNull(expected); expected = PageableGUITest.generateExpected(expected.copy(), i); - for (int s : slots) - expected.setContents(s, cc.apply(data[s + i * slots.length])); + for (int s = 0; s < slots.length; s++) + expected.setContents(slots[s], cc.apply(data[s + i * slots.length])); GUI actual = viewer.openedGUI; actual.getContents(0).forEach(e -> e.onClickItem((GUIItemAction) null)); From beb258c923c0eec5dc46cc2f49956c9173f4a9c2 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:48:55 +0200 Subject: [PATCH 140/204] Added displayName to items --- .../src/test/java/it/angrybear/yagl/guis/DataGUITest.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 086f2634..53bfe2b6 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -79,7 +79,9 @@ void testOpenPage() { 1.1, 1.2, 1.3, 1.5, 1.6, 1.7, 2.1, 2.2, 2.3, 2.5, 2.6, 2.7, }; - Function cc = d -> ItemGUIContent.newInstance().setAmount((int) (d * 10)); + Function cc = d -> ItemGUIContent.newInstance() + .setDisplayName("Data: " + d) + .setAmount((int) (d * 10)); PageableGUI gui = DataGUI.newGUI(9, cc, data) .setPreviousPage(0, Item.newItem("redstone_block") .setDisplayName("&7Go to page &e")) From c4e433366d4360b8870eb533a62f00198f3a4397 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 19:57:48 +0200 Subject: [PATCH 141/204] Fixed tests slots --- .../it/angrybear/yagl/guis/DataGUITest.java | 24 +++++++++++++------ 1 file changed, 17 insertions(+), 7 deletions(-) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 53bfe2b6..4a70bc6e 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -73,11 +73,16 @@ void testPagesMethod(int contents, int data, int expected) { @Test void testOpenPage() { - int[] slots = new int[]{1, 2, 3, 5, 6, 7}; + int[][] slots = new int[][]{ + new int[]{0, 1, 2, 3, 5, 6, 7}, + new int[]{1, 2, 3, 5, 6, 7}, + new int[]{1, 2, 3, 5, 6, 7, 8} + }; + Double[] data = new Double[] { - 0.1, 0.2, 0.3, 0.5, 0.6, 0.7, - 1.1, 1.2, 1.3, 1.5, 1.6, 1.7, - 2.1, 2.2, 2.3, 2.5, 2.6, 2.7, + 0.0, 0.1, 0.2, 0.3, 0.5, 0.6, 0.7, + 1.1, 1.2, 1.3, 1.5, 1.6, 1.7, + 2.1, 2.2, 2.3, 2.5, 2.6, 2.7, 2.8, }; Function cc = d -> ItemGUIContent.newInstance() .setDisplayName("Data: " + d) @@ -100,14 +105,19 @@ void testOpenPage() { assertNotNull(expected); expected = PageableGUITest.generateExpected(expected.copy(), i); - for (int s = 0; s < slots.length; s++) - expected.setContents(slots[s], cc.apply(data[s + i * slots.length])); + int[] tmpSlots = slots[i]; + for (int s = 0; s < tmpSlots.length; s++) { + int ind = s; + if (i > 0) ind += slots[i - 1].length; + double d = data[ind]; + expected.setContents(tmpSlots[s], cc.apply(d)); + } GUI actual = viewer.openedGUI; actual.getContents(0).forEach(e -> e.onClickItem((GUIItemAction) null)); actual.getContents(8).forEach(e -> e.onClickItem((GUIItemAction) null)); - assertEquals(expected, actual); + assertEquals(expected, actual, String.format("Invalid page %s", i)); } } } From 44319c5ffdc316e2b65078dc71774900184394e5 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 20:02:38 +0200 Subject: [PATCH 142/204] Fixed prepareOpenGUI method not returning correct GUI --- .../src/main/java/it/angrybear/yagl/guis/PageableGUI.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java index 59a29fb1..dcfbca88 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java @@ -200,16 +200,16 @@ public void open(final @NotNull Viewer viewer, final int page) { * @return the gui */ protected @NotNull GUI prepareOpenGUI(final @NotNull GUI gui, final int page) { - gui.copy().copyFrom(this, false) + GUI newGUI = gui.copy().copyFrom(this, false) .setVariable("page", String.valueOf(page + 1)) .setVariable("previous-page", String.valueOf(page)) .setVariable("next-page", String.valueOf(page + 2)) .setVariable("pages", String.valueOf(pages())); if (page > 0) this.previousPage.ifPresent((s, p) -> - gui.setContents(s, p.copy().onClickItem((v, g, i) -> open(v, page - 1)))); + newGUI.setContents(s, p.copy().onClickItem((v, g, i) -> open(v, page - 1)))); if (page + 1 < pages()) this.nextPage.ifPresent((s, p) -> - gui.setContents(s, p.copy().onClickItem((v, g, i) -> open(v, page + 1)))); - return gui; + newGUI.setContents(s, p.copy().onClickItem((v, g, i) -> open(v, page + 1)))); + return newGUI; } @Override From 5e23444b5c4c2949d35436886de4accbce298033 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 20:04:49 +0200 Subject: [PATCH 143/204] Added exception in case of empty slots empty for pages method --- gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 5501e7a5..7e8a6dda 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -178,7 +178,10 @@ public PageableGUI setPages(int pages) { */ @Override public int pages() { - double pages = (double) this.data.size() / emptySlots().size(); + int emptySlots = emptySlots().size(); + if (emptySlots == 0) + throw new IllegalStateException("Cannot set data for non-empty pages"); + double pages = (double) this.data.size() / emptySlots; return (int) Math.ceil(pages); } From b57b39213c392c544db22d252ff52a05eefd5c4a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 20:18:05 +0200 Subject: [PATCH 144/204] Fixed copy methods not trying to copy with copy method in iterables --- .../src/main/java/it/angrybear/yagl/utils/ObjectUtils.java | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java index 77546c28..8aa57078 100644 --- a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java +++ b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java @@ -87,13 +87,14 @@ public static O copy(final @NotNull T t, @NotNull Class claz private static @NotNull Object[] copyArray(final @NotNull Object obj1) { Object[] tmp = (Object[]) obj1; Object[] arr = (Object[]) Array.newInstance(obj1.getClass().getComponentType(), tmp.length); - System.arraycopy(tmp, 0, arr, 0, arr.length); + for (int i = 0; i < tmp.length; i++) arr[i] = copyWithMethod(tmp[i]); return arr; } private static @NotNull Map copyMap(final @NotNull Object obj1) { Map map = new HashMap<>(); - ((Map) obj1).putAll(map); + ((Map) obj1).forEach((k, v) -> + map.put(copyWithMethod(k), copyWithMethod(v))); return map; } @@ -104,6 +105,7 @@ public static O copy(final @NotNull T t, @NotNull Class claz tmpClass = ArrayList.class; Class> finalClass = (Class>) tmpClass; return ((Collection) obj1).stream() + .map(ObjectUtils::copyWithMethod) .collect(Collectors.toCollection(() -> new Refl<>(finalClass, new Object[0]).getObject())); } From 62fed4838fae9add0432abc625be4e448df6d30f Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 20:18:47 +0200 Subject: [PATCH 145/204] Fixed copyWithMethod to support null objects --- .../src/main/java/it/angrybear/yagl/utils/ObjectUtils.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java index 8aa57078..1bb9cfd4 100644 --- a/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java +++ b/common/base/src/main/java/it/angrybear/yagl/utils/ObjectUtils.java @@ -5,6 +5,7 @@ import lombok.AccessLevel; import lombok.NoArgsConstructor; import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; import java.lang.reflect.Array; import java.lang.reflect.Field; @@ -109,8 +110,9 @@ public static O copy(final @NotNull T t, @NotNull Class claz .collect(Collectors.toCollection(() -> new Refl<>(finalClass, new Object[0]).getObject())); } - private static @NotNull Object copyWithMethod(final @NotNull Object obj1) { + private static @Nullable Object copyWithMethod(final @Nullable Object obj1) { try { + if (obj1 == null) return null; Method copy = obj1.getClass().getDeclaredMethod("copy"); return ReflectionUtils.setAccessible(copy) .map(m -> m.invoke(obj1)) From ad040723878cb2e673326af077f5e898e674c7bf Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 20:20:42 +0200 Subject: [PATCH 146/204] Added copy method --- .../main/java/it/angrybear/yagl/guis/GUIImpl.java | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/GUIImpl.java b/gui/base/src/main/java/it/angrybear/yagl/guis/GUIImpl.java index 6bad1dee..db75eabb 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/GUIImpl.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/GUIImpl.java @@ -231,10 +231,21 @@ protected Contents(final GUIContent @NotNull ... contents) { * * @return the contents */ - public List getContents() { + public @NotNull List getContents() { return Arrays.asList(this.contents); } + /** + * Copies the current object to a new one. + * + * @return the copy + */ + public @NotNull Contents copy() { + return new GUIImpl.Contents(Arrays.stream(this.contents) + .map(c -> c == null ? null : c.copy()) + .toArray(GUIContent[]::new)); + } + @Override public boolean equals(Object o) { if (o instanceof Contents) { From 764a5202854f057a2012e5a4ec2e4e6312b6f9da Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 20:21:26 +0200 Subject: [PATCH 147/204] Revert "Fixed open method" This reverts commit d46e443d5e132f12463da7f94b3adc425a4442e8. --- gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 7e8a6dda..f247fdf0 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -132,7 +132,7 @@ public DataGUI clearData() { public void open(@NotNull Viewer viewer, int page) { GUI templateGUI = this.templateGUI; if (templateGUI == null) throw new IllegalStateException("templateGUI did not load correctly"); - prepareOpenGUI(fillContents(templateGUI, page), page).open(viewer); + fillContents(prepareOpenGUI(templateGUI, page), page).open(viewer); } private @NotNull GUI fillContents(final @NotNull GUI gui, final int page) { From 117e9fd499a6a0dae4a74b19fd09cfc6217ab24d Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 20:24:12 +0200 Subject: [PATCH 148/204] Fixed visibility issues --- .../src/main/java/it/angrybear/yagl/guis/PageableGUI.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java index 11165c7e..11668e9b 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java @@ -22,8 +22,8 @@ public class PageableGUI extends FieldEquable implements Iterable, Metadata private final List pages = new LinkedList<>(); private final Map variables = new HashMap<>(); - private final Tuple previousPage = new Tuple<>(); - private final Tuple nextPage = new Tuple<>(); + protected final Tuple previousPage = new Tuple<>(); + protected final Tuple nextPage = new Tuple<>(); /** * Instantiates a new Pageable gui. From edf9d046928dac8ae42b7f1e4d936683605937db Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 20:43:32 +0200 Subject: [PATCH 149/204] Reworked pages method --- .../java/it/angrybear/yagl/guis/DataGUI.java | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index f247fdf0..dd5f31bb 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -181,8 +181,22 @@ public int pages() { int emptySlots = emptySlots().size(); if (emptySlots == 0) throw new IllegalStateException("Cannot set data for non-empty pages"); - double pages = (double) this.data.size() / emptySlots; - return (int) Math.ceil(pages); + int size = this.data.size(); + int pages = size % emptySlots == 0 ? 0 : 1; + if (size < emptySlots) return pages; + int add = 0; + if (this.previousPage.isPresent()) { + pages++; + size -= emptySlots - (this.nextPage.isEmpty() ? 1 : 0); + add--; + } + if (this.nextPage.isPresent()) { + pages++; + size -= emptySlots + add; + add--; + } + while ((size -= emptySlots + add) >= 0) pages++; + return pages; } /** From c3e58d28305103a10844466d95e6037608e52c77 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:04:01 +0200 Subject: [PATCH 150/204] Fixed tests of empty slots --- gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 4a70bc6e..19087b26 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -108,7 +108,7 @@ void testOpenPage() { int[] tmpSlots = slots[i]; for (int s = 0; s < tmpSlots.length; s++) { int ind = s; - if (i > 0) ind += slots[i - 1].length; + for (int k = i; k > 0; k--) ind += slots[k - 1].length; double d = data[ind]; expected.setContents(tmpSlots[s], cc.apply(d)); } From edeb8ecdb0e8728f6ae712b803400d20f8c05f6a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:04:44 +0200 Subject: [PATCH 151/204] Reworked fillContents method to keep track of previous and next pages --- .../java/it/angrybear/yagl/guis/DataGUI.java | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index dd5f31bb..22b4e818 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -136,12 +136,19 @@ public void open(@NotNull Viewer viewer, int page) { } private @NotNull GUI fillContents(final @NotNull GUI gui, final int page) { - int emptySlots = gui.emptySlots().size(); + int emptySlots = emptySlots().size(); + if (this.previousPage.isPresent()) emptySlots--; + if (this.nextPage.isPresent()) emptySlots--; int min = emptySlots * page; - int max = emptySlots * (page + 1); - int size = this.data.size(); - for (int i = Math.min(min, size); i < Math.min(max, size); i++) - gui.addContent(this.dataConverter.apply(this.data.get(i))); + if (min >= this.data.size()) + throw new IllegalArgumentException(String.format("No such page '%s'", page)); + if (page > 0) min++; + int size = Math.min(gui.emptySlots().size() + min, this.data.size()); + for (int i = min; i < size; i++) { + T data = this.data.get(i); + GUIContent content = this.dataConverter.apply(data); + gui.addContent(content); + } return gui; } From e380d22e4ceea2f306b02e0a783b9f2de7721fe0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:04:44 +0200 Subject: [PATCH 152/204] Reworked fillContents method to keep track of previous and next pages Closes #6 --- .../java/it/angrybear/yagl/guis/DataGUI.java | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index dd5f31bb..22b4e818 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -136,12 +136,19 @@ public void open(@NotNull Viewer viewer, int page) { } private @NotNull GUI fillContents(final @NotNull GUI gui, final int page) { - int emptySlots = gui.emptySlots().size(); + int emptySlots = emptySlots().size(); + if (this.previousPage.isPresent()) emptySlots--; + if (this.nextPage.isPresent()) emptySlots--; int min = emptySlots * page; - int max = emptySlots * (page + 1); - int size = this.data.size(); - for (int i = Math.min(min, size); i < Math.min(max, size); i++) - gui.addContent(this.dataConverter.apply(this.data.get(i))); + if (min >= this.data.size()) + throw new IllegalArgumentException(String.format("No such page '%s'", page)); + if (page > 0) min++; + int size = Math.min(gui.emptySlots().size() + min, this.data.size()); + for (int i = min; i < size; i++) { + T data = this.data.get(i); + GUIContent content = this.dataConverter.apply(data); + gui.addContent(content); + } return gui; } From a930007bd300c64c786ab0b8e1a6b0f7ae7ec9c6 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:11:36 +0200 Subject: [PATCH 153/204] Added tests for return types --- .../src/test/java/it/angrybear/yagl/guis/DataGUITest.java | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 19087b26..4269d2cf 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -1,5 +1,6 @@ package it.angrybear.yagl.guis; +import it.angrybear.yagl.TestUtils; import it.angrybear.yagl.actions.GUIItemAction; import it.angrybear.yagl.contents.GUIContent; import it.angrybear.yagl.contents.ItemGUIContent; @@ -121,4 +122,10 @@ void testOpenPage() { } } } + + @Test + void testReturnTypes() { + TestUtils.testReturnType(DataGUI.newGUI(9, c -> null), GUI.class, m -> m.getName().equals("copy")); + } + } \ No newline at end of file From d3d57f278fa97484429ac166910ea0620e936f53 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:21:38 +0200 Subject: [PATCH 154/204] Inferred nullity --- .../java/it/angrybear/yagl/guis/DataGUI.java | 36 +++++++++---------- .../main/java/it/angrybear/yagl/guis/GUI.java | 8 ++--- .../java/it/angrybear/yagl/guis/GUIImpl.java | 10 +++--- .../it/angrybear/yagl/guis/PageableGUI.java | 24 ++++++------- .../java/it/angrybear/yagl/guis/TypeGUI.java | 4 +-- 5 files changed, 41 insertions(+), 41 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 22b4e818..5b0c1f63 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -19,8 +19,8 @@ public class DataGUI extends PageableGUI { private static final String ERROR_MESSAGE = "Pages are dynamically calculated when opening this GUI. They cannot be singly edited"; - private final List data; - private final Function dataConverter; + private final @NotNull List data; + private final @NotNull Function dataConverter; /** * Instantiates a new Data gui. @@ -52,7 +52,7 @@ public class DataGUI extends PageableGUI { * @param data the data * @return this gui */ - public DataGUI addData(final T @NotNull ... data) { + public @NotNull DataGUI addData(final T @NotNull ... data) { return addData(Arrays.asList(data)); } @@ -62,7 +62,7 @@ public DataGUI addData(final T @NotNull ... data) { * @param data the data * @return this gui */ - public DataGUI addData(final @NotNull Collection data) { + public @NotNull DataGUI addData(final @NotNull Collection data) { this.data.addAll(data); return this; } @@ -73,7 +73,7 @@ public DataGUI addData(final @NotNull Collection data) { * @param data the data * @return the data */ - public DataGUI setData(final T @NotNull ... data) { + public @NotNull DataGUI setData(final T @NotNull ... data) { return setData(Arrays.asList(data)); } @@ -83,7 +83,7 @@ public DataGUI setData(final T @NotNull ... data) { * @param data the data * @return the data */ - public DataGUI setData(final @NotNull Collection data) { + public @NotNull DataGUI setData(final @NotNull Collection data) { return clearData().addData(data); } @@ -93,7 +93,7 @@ public DataGUI setData(final @NotNull Collection data) { * @param data the data * @return this gui */ - public DataGUI removeData(final T @NotNull ... data) { + public @NotNull DataGUI removeData(final T @NotNull ... data) { return removeData(Arrays.asList(data)); } @@ -103,7 +103,7 @@ public DataGUI removeData(final T @NotNull ... data) { * @param data the data * @return this gui */ - public DataGUI removeData(final @NotNull Collection data) { + public @NotNull DataGUI removeData(final @NotNull Collection data) { return removeData(t -> t.equals(data)); } @@ -113,7 +113,7 @@ public DataGUI removeData(final @NotNull Collection data) { * @param function the function * @return this gui */ - public DataGUI removeData(final @NotNull Predicate function) { + public @NotNull DataGUI removeData(final @NotNull Predicate function) { this.data.removeIf(function); return this; } @@ -123,7 +123,7 @@ public DataGUI removeData(final @NotNull Predicate function) { * * @return this gui */ - public DataGUI clearData() { + public @NotNull DataGUI clearData() { this.data.clear(); return this; } @@ -162,7 +162,7 @@ public void open(@NotNull Viewer viewer, int page) { */ @Override @Deprecated - public GUI getPage(int page) { + public @NotNull GUI getPage(int page) { throw new IllegalStateException(ERROR_MESSAGE); } @@ -174,7 +174,7 @@ public GUI getPage(int page) { * @return this gui */ @Override - public PageableGUI setPages(int pages) { + public @NotNull PageableGUI setPages(int pages) { throw new IllegalStateException(ERROR_MESSAGE); } @@ -214,7 +214,7 @@ public int pages() { * @param dataConverter the data converter * @return the data gui */ - public static DataGUI newGUI(final int size, final @NotNull Function dataConverter) { + public static @NotNull DataGUI newGUI(final int size, final @NotNull Function dataConverter) { return new DataGUI<>(size, dataConverter); } @@ -228,7 +228,7 @@ public static DataGUI newGUI(final int size, final @NotNull Function DataGUI newGUI(final int size, final @NotNull Function dataConverter, + public static @NotNull DataGUI newGUI(final int size, final @NotNull Function dataConverter, final T @NotNull ... data) { return new DataGUI<>(size, dataConverter).setData(data); } @@ -242,7 +242,7 @@ public static DataGUI newGUI(final int size, final @NotNull Function DataGUI newGUI(final int size, final @NotNull Function dataConverter, + public static @NotNull DataGUI newGUI(final int size, final @NotNull Function dataConverter, final @NotNull Collection data) { return new DataGUI<>(size, dataConverter).setData(data); } @@ -255,7 +255,7 @@ public static DataGUI newGUI(final int size, final @NotNull Function DataGUI newGUI(final @NotNull GUIType type, final @NotNull Function dataConverter) { + public static @NotNull DataGUI newGUI(final @NotNull GUIType type, final @NotNull Function dataConverter) { return new DataGUI<>(type, dataConverter); } @@ -269,7 +269,7 @@ public static DataGUI newGUI(final @NotNull GUIType type, final @NotNull * @return the data gui */ @SafeVarargs - public static DataGUI newGUI(final @NotNull GUIType type, final @NotNull Function dataConverter, + public static @NotNull DataGUI newGUI(final @NotNull GUIType type, final @NotNull Function dataConverter, final T @NotNull ... data) { return new DataGUI<>(type, dataConverter).setData(data); } @@ -283,7 +283,7 @@ public static DataGUI newGUI(final @NotNull GUIType type, final @NotNull * @param data the data * @return the data gui */ - public static DataGUI newGUI(final @NotNull GUIType type, final @NotNull Function dataConverter, + public static @NotNull DataGUI newGUI(final @NotNull GUIType type, final @NotNull Function dataConverter, final @NotNull Collection data) { return new DataGUI<>(type, dataConverter).setData(data); } diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/GUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/GUI.java index 86dcdb80..1236b835 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/GUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/GUI.java @@ -1168,7 +1168,7 @@ default int southEast() { * * @return the slots */ - default Set emptySlots() { + default @NotNull Set emptySlots() { Set slots = new HashSet<>(); for (int i = 0; i < size(); i++) if (getContents(i).isEmpty()) slots.add(i); @@ -1373,7 +1373,7 @@ default GUI copy() { * @param size the size * @return the gui */ - static GUI newGUI(final int size) { + static @NotNull GUI newGUI(final int size) { return new DefaultGUI(size); } @@ -1386,7 +1386,7 @@ static GUI newGUI(final int size) { * @param size the size * @return the resizable gui */ - static ResizableGUI newResizableGUI(final int size) { + static @NotNull ResizableGUI newResizableGUI(final int size) { return new ResizableGUI(size); } @@ -1396,7 +1396,7 @@ static ResizableGUI newResizableGUI(final int size) { * @param type the type * @return the gui */ - static GUI newGUI(final GUIType type) { + static @NotNull GUI newGUI(final @NotNull GUIType type) { return new TypeGUI(type); } } diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/GUIImpl.java b/gui/base/src/main/java/it/angrybear/yagl/guis/GUIImpl.java index db75eabb..10247b74 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/GUIImpl.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/GUIImpl.java @@ -20,9 +20,9 @@ abstract class GUIImpl extends FieldEquable implements GUI { protected static final int MAX_SIZE = 54; @Getter - protected String title; + protected @Nullable String title; protected List contents; - protected final Set movableSlots; + protected final @NotNull Set movableSlots; protected final Map variables = new HashMap<>(); protected GUIAction clickOutsideAction; @@ -202,7 +202,7 @@ protected int addSingle(final @NotNull GUIContent content, int index) { * @param copyFrom if not null, copy the contents of this list in the resulting one * @return the list */ - protected List createContents(int size, final List copyFrom) { + protected @NotNull List createContents(int size, final @Nullable List copyFrom) { List contents = new LinkedList<>(); for (int i = 0; i < size; i++) contents.add(null); if (copyFrom != null) @@ -215,7 +215,7 @@ protected List createContents(int size, final List copyFrom) * A type to keep track of multiple {@link GUIContent} for one slot. */ public static class Contents { - private final GUIContent[] contents; + private final GUIContent @NotNull [] contents; /** * Instantiates a new Contents. @@ -274,7 +274,7 @@ public int hashCode() { } @Override - public String toString() { + public @NotNull String toString() { return Arrays.toString(this.contents); } } diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java index 11668e9b..ccdd0e29 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java @@ -18,7 +18,7 @@ * An implementation of {@link GUI} that allows multiple GUI pages to be added. */ public class PageableGUI extends FieldEquable implements Iterable, Metadatable, GUI { - protected final GUI templateGUI; + protected final @NotNull GUI templateGUI; private final List pages = new LinkedList<>(); private final Map variables = new HashMap<>(); @@ -29,7 +29,7 @@ public class PageableGUI extends FieldEquable implements Iterable, Metadata * Instantiates a new Pageable gui. */ PageableGUI() { - this.templateGUI = null; + this.templateGUI = new DefaultGUI(); } /** @@ -66,7 +66,7 @@ public int pages() { * @param page the page * @return the corresponding {@link GUI} page */ - public GUI getPage(final int page) { + public @NotNull GUI getPage(final int page) { try { return this.pages.get(page); } catch (IndexOutOfBoundsException e) { @@ -80,7 +80,7 @@ public GUI getPage(final int page) { * @param pages the pages * @return this gui */ - public PageableGUI setPages(final int pages) { + public @NotNull PageableGUI setPages(final int pages) { if (pages < 0) throw new IllegalArgumentException(String.format("Invalid pages '%s'", pages)); int s; while ((s = this.pages.size()) - pages > 0) this.pages.remove(s - 1); @@ -96,7 +96,7 @@ public PageableGUI setPages(final int pages) { * @param previousPage the previous page * @return the previous page */ - public PageableGUI setPreviousPage(final int slot, final @NotNull Item previousPage) { + public @NotNull PageableGUI setPreviousPage(final int slot, final @NotNull Item previousPage) { return setPreviousPage(slot, (GUIContent) ItemGUIContent.newInstance(previousPage)); } @@ -108,7 +108,7 @@ public PageableGUI setPreviousPage(final int slot, final @NotNull Item previousP * @param previousPage the previous page * @return the previous page */ - public PageableGUI setPreviousPage(final int slot, final @NotNull GUIContent previousPage) { + public @NotNull PageableGUI setPreviousPage(final int slot, final @NotNull GUIContent previousPage) { this.previousPage.set(checkSlot(slot), previousPage); return this; } @@ -118,7 +118,7 @@ public PageableGUI setPreviousPage(final int slot, final @NotNull GUIContent pre * * @return the pageable gui */ - public PageableGUI unsetPreviousPage() { + public @NotNull PageableGUI unsetPreviousPage() { this.previousPage.set(null, null); return this; } @@ -131,7 +131,7 @@ public PageableGUI unsetPreviousPage() { * @param nextPage the next page * @return the next page */ - public PageableGUI setNextPage(final int slot, final @NotNull Item nextPage) { + public @NotNull PageableGUI setNextPage(final int slot, final @NotNull Item nextPage) { return setNextPage(slot, (GUIContent) ItemGUIContent.newInstance(nextPage)); } @@ -143,7 +143,7 @@ public PageableGUI setNextPage(final int slot, final @NotNull Item nextPage) { * @param nextPage the next page * @return the next page */ - public PageableGUI setNextPage(final int slot, final @NotNull GUIContent nextPage) { + public @NotNull PageableGUI setNextPage(final int slot, final @NotNull GUIContent nextPage) { this.nextPage.set(checkSlot(slot), nextPage); return this; } @@ -153,7 +153,7 @@ public PageableGUI setNextPage(final int slot, final @NotNull GUIContent nextPag * * @return the pageable gui */ - public PageableGUI unsetNextPage() { + public @NotNull PageableGUI unsetNextPage() { this.nextPage.set(null, null); return this; } @@ -798,7 +798,7 @@ public PageableGUI copy() { * @param size the size * @return the pageable gui */ - public static PageableGUI newGUI(final int size) { + public static @NotNull PageableGUI newGUI(final int size) { return new PageableGUI(size); } @@ -808,7 +808,7 @@ public static PageableGUI newGUI(final int size) { * @param type the type * @return the pageable gui */ - public static PageableGUI newGUI(final @NotNull GUIType type) { + public static @NotNull PageableGUI newGUI(final @NotNull GUIType type) { return new PageableGUI(type); } diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/TypeGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/TypeGUI.java index 1111211b..1183e685 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/TypeGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/TypeGUI.java @@ -21,13 +21,13 @@ public class TypeGUI extends GUIImpl { private static final int LOOM_MIDDLE_LINE = 0; private static final int LOOM_SOUTH = 2; - private final GUIType inventoryType; + private final @NotNull GUIType inventoryType; /** * Internal constructor, used for serializing purposes. */ private TypeGUI() { - this.inventoryType = null; + this.inventoryType = GUIType.CHEST; } /** From 08d098ffefc46eaef949720ae19b954ed874c04e Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:22:35 +0200 Subject: [PATCH 155/204] Refactored code --- .../java/it/angrybear/yagl/guis/DataGUI.java | 56 +++++++++---------- 1 file changed, 27 insertions(+), 29 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 5b0c1f63..32473fc8 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -130,9 +130,7 @@ public class DataGUI extends PageableGUI { @Override public void open(@NotNull Viewer viewer, int page) { - GUI templateGUI = this.templateGUI; - if (templateGUI == null) throw new IllegalStateException("templateGUI did not load correctly"); - fillContents(prepareOpenGUI(templateGUI, page), page).open(viewer); + fillContents(prepareOpenGUI(this.templateGUI, page), page).open(viewer); } private @NotNull GUI fillContents(final @NotNull GUI gui, final int page) { @@ -152,32 +150,6 @@ public void open(@NotNull Viewer viewer, int page) { return gui; } - /** - * Gets the {@link GUI} page from the given index. - * The index starts from 0. - * - * @param page the page - * @deprecated In {@link DataGUI}s pages are not pre-defined, but rather calculated upon opening. - * @return the corresponding {@link GUI} page - */ - @Override - @Deprecated - public @NotNull GUI getPage(int page) { - throw new IllegalStateException(ERROR_MESSAGE); - } - - /** - * Sets pages. - * - * @param pages the pages - * @deprecated In {@link DataGUI}s pages are not pre-defined, but rather calculated upon opening. - * @return this gui - */ - @Override - public @NotNull PageableGUI setPages(int pages) { - throw new IllegalStateException(ERROR_MESSAGE); - } - /** * Gets the number of pages based on the amount of data provided. * @@ -206,6 +178,32 @@ public int pages() { return pages; } + /** + * Gets the {@link GUI} page from the given index. + * The index starts from 0. + * + * @param page the page + * @deprecated In {@link DataGUI}s pages are not pre-defined, but rather calculated upon opening. + * @return the corresponding {@link GUI} page + */ + @Override + @Deprecated + public @NotNull GUI getPage(int page) { + throw new IllegalStateException(ERROR_MESSAGE); + } + + /** + * Sets pages. + * + * @param pages the pages + * @deprecated In {@link DataGUI}s pages are not pre-defined, but rather calculated upon opening. + * @return this gui + */ + @Override + public @NotNull DataGUI setPages(int pages) { + throw new IllegalStateException(ERROR_MESSAGE); + } + /** * Creates a new {@link DataGUI} with the given size and converter. * From 873c428eb28d0e96419a277ab4c15f4de8ea13ec Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:25:38 +0200 Subject: [PATCH 156/204] Overridden methods return type --- .../java/it/angrybear/yagl/guis/DataGUI.java | 532 ++++++++++++++++++ 1 file changed, 532 insertions(+) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 32473fc8..c6a1e98f 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -1,8 +1,14 @@ package it.angrybear.yagl.guis; +import it.angrybear.yagl.Metadatable; +import it.angrybear.yagl.actions.BiGUIAction; +import it.angrybear.yagl.actions.GUIAction; import it.angrybear.yagl.contents.GUIContent; +import it.angrybear.yagl.contents.ItemGUIContent; +import it.angrybear.yagl.items.Item; import it.angrybear.yagl.viewers.Viewer; import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; import java.util.Arrays; import java.util.Collection; @@ -16,6 +22,7 @@ * * @param the type of the data */ +@SuppressWarnings("unchecked") public class DataGUI extends PageableGUI { private static final String ERROR_MESSAGE = "Pages are dynamically calculated when opening this GUI. They cannot be singly edited"; @@ -204,6 +211,531 @@ public int pages() { throw new IllegalStateException(ERROR_MESSAGE); } + @Override + public @NotNull DataGUI setPreviousPage(int slot, @NotNull Item previousPage) { + return (DataGUI) super.setPreviousPage(slot, previousPage); + } + + @Override + public @NotNull DataGUI setPreviousPage(int slot, @NotNull GUIContent previousPage) { + return (DataGUI) super.setPreviousPage(slot, previousPage); + } + + @Override + public @NotNull DataGUI unsetPreviousPage() { + return (DataGUI) super.unsetPreviousPage(); + } + + @Override + public @NotNull DataGUI setNextPage(int slot, @NotNull Item nextPage) { + return (DataGUI) super.setNextPage(slot, nextPage); + } + + @Override + public @NotNull DataGUI setNextPage(int slot, @NotNull GUIContent nextPage) { + return (DataGUI) super.setNextPage(slot, nextPage); + } + + @Override + public @NotNull DataGUI unsetNextPage() { + return (DataGUI) super.unsetNextPage(); + } + + @Override + public @NotNull DataGUI setTitle(@Nullable String title) { + return (DataGUI) super.setTitle(title); + } + + @Override + public @NotNull DataGUI setMovable(int slot, boolean movable) { + return (DataGUI) super.setMovable(slot, movable); + } + + @Override + public @NotNull DataGUI addContent(GUIContent @NotNull ... contents) { + return (DataGUI) super.addContent(contents); + } + + @Override + public @NotNull DataGUI setContents(int slot, GUIContent @NotNull ... contents) { + return (DataGUI) super.setContents(slot, contents); + } + + @Override + public @NotNull DataGUI setContents(int slot, @NotNull Collection contents) { + return (DataGUI) super.setContents(slot, contents); + } + + @Override + public @NotNull DataGUI unsetContent(int slot) { + return (DataGUI) super.unsetContent(slot); + } + + @Override + public @NotNull DataGUI onClickOutside(@NotNull GUIAction action) { + return (DataGUI) super.onClickOutside(action); + } + + @Override + public @NotNull DataGUI onOpenGUI(@NotNull GUIAction action) { + return (DataGUI) super.onOpenGUI(action); + } + + @Override + public @NotNull DataGUI onCloseGUI(@NotNull GUIAction action) { + return (DataGUI) super.onCloseGUI(action); + } + + @Override + public @NotNull DataGUI onChangeGUI(@NotNull BiGUIAction action) { + return (DataGUI) super.onChangeGUI(action); + } + + @Override + public @NotNull DataGUI setAllMovable() { + return (DataGUI) super.setAllMovable(); + } + + @Override + public @NotNull DataGUI setAllUnmovable() { + return (DataGUI) super.setAllUnmovable(); + } + + @Override + public @NotNull DataGUI addContent(Item @NotNull ... contents) { + return (DataGUI) super.addContent(contents); + } + + @Override + public @NotNull DataGUI addContent(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.addContent(contents); + } + + @Override + public @NotNull DataGUI setContents(int slot, Item @NotNull ... contents) { + return (DataGUI) super.setContents(slot, contents); + } + + @Override + public @NotNull DataGUI setContents(int slot, ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setContents(slot, contents); + } + + @Override + public @NotNull DataGUI setAllSides(Item @NotNull ... contents) { + return (DataGUI) super.setAllSides(contents); + } + + @Override + public @NotNull DataGUI setAllSides(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setAllSides(contents); + } + + @Override + public @NotNull DataGUI setAllSides(GUIContent @NotNull ... contents) { + return (DataGUI) super.setAllSides(contents); + } + + @Override + public @NotNull DataGUI setAllSides(@NotNull Collection contents) { + return (DataGUI) super.setAllSides(contents); + } + + @Override + public @NotNull DataGUI unsetAllSides() { + return (DataGUI) super.unsetAllSides(); + } + + @Override + public @NotNull DataGUI setTopAndBottomSides(Item @NotNull ... contents) { + return (DataGUI) super.setTopAndBottomSides(contents); + } + + @Override + public @NotNull DataGUI setTopAndBottomSides(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setTopAndBottomSides(contents); + } + + @Override + public @NotNull DataGUI setTopAndBottomSides(GUIContent @NotNull ... contents) { + return (DataGUI) super.setTopAndBottomSides(contents); + } + + @Override + public @NotNull DataGUI setTopAndBottomSides(@NotNull Collection contents) { + return (DataGUI) super.setTopAndBottomSides(contents); + } + + @Override + public @NotNull DataGUI unsetTopAndBottomSides() { + return (DataGUI) super.unsetTopAndBottomSides(); + } + + @Override + public @NotNull DataGUI setLeftAndRightSides(Item @NotNull ... contents) { + return (DataGUI) super.setLeftAndRightSides(contents); + } + + @Override + public @NotNull DataGUI setLeftAndRightSides(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setLeftAndRightSides(contents); + } + + @Override + public @NotNull DataGUI setLeftAndRightSides(GUIContent @NotNull ... contents) { + return (DataGUI) super.setLeftAndRightSides(contents); + } + + @Override + public @NotNull DataGUI setLeftAndRightSides(@NotNull Collection contents) { + return (DataGUI) super.setLeftAndRightSides(contents); + } + + @Override + public @NotNull DataGUI unsetLeftAndRightSides() { + return (DataGUI) super.unsetLeftAndRightSides(); + } + + @Override + public @NotNull DataGUI setTopSide(Item @NotNull ... contents) { + return (DataGUI) super.setTopSide(contents); + } + + @Override + public @NotNull DataGUI setTopSide(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setTopSide(contents); + } + + @Override + public @NotNull DataGUI setTopSide(GUIContent @NotNull ... contents) { + return (DataGUI) super.setTopSide(contents); + } + + @Override + public @NotNull DataGUI setTopSide(@NotNull Collection contents) { + return (DataGUI) super.setTopSide(contents); + } + + @Override + public @NotNull DataGUI unsetTopSide() { + return (DataGUI) super.unsetTopSide(); + } + + @Override + public @NotNull DataGUI setLeftSide(Item @NotNull ... contents) { + return (DataGUI) super.setLeftSide(contents); + } + + @Override + public @NotNull DataGUI setLeftSide(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setLeftSide(contents); + } + + @Override + public @NotNull DataGUI setLeftSide(GUIContent @NotNull ... contents) { + return (DataGUI) super.setLeftSide(contents); + } + + @Override + public @NotNull DataGUI setLeftSide(@NotNull Collection contents) { + return (DataGUI) super.setLeftSide(contents); + } + + @Override + public @NotNull DataGUI unsetLeftSide() { + return (DataGUI) super.unsetLeftSide(); + } + + @Override + public @NotNull DataGUI setBottomSide(Item @NotNull ... contents) { + return (DataGUI) super.setBottomSide(contents); + } + + @Override + public @NotNull DataGUI setBottomSide(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setBottomSide(contents); + } + + @Override + public @NotNull DataGUI setBottomSide(GUIContent @NotNull ... contents) { + return (DataGUI) super.setBottomSide(contents); + } + + @Override + public @NotNull DataGUI setBottomSide(@NotNull Collection contents) { + return (DataGUI) super.setBottomSide(contents); + } + + @Override + public @NotNull DataGUI unsetBottomSide() { + return (DataGUI) super.unsetBottomSide(); + } + + @Override + public @NotNull DataGUI setRightSide(Item @NotNull ... contents) { + return (DataGUI) super.setRightSide(contents); + } + + @Override + public @NotNull DataGUI setRightSide(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setRightSide(contents); + } + + @Override + public @NotNull DataGUI setRightSide(GUIContent @NotNull ... contents) { + return (DataGUI) super.setRightSide(contents); + } + + @Override + public @NotNull DataGUI setRightSide(@NotNull Collection contents) { + return (DataGUI) super.setRightSide(contents); + } + + @Override + public @NotNull DataGUI unsetRightSide() { + return (DataGUI) super.unsetRightSide(); + } + + @Override + public @NotNull DataGUI setNorthWest(Item @NotNull ... contents) { + return (DataGUI) super.setNorthWest(contents); + } + + @Override + public @NotNull DataGUI setNorthWest(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setNorthWest(contents); + } + + @Override + public @NotNull DataGUI setNorthWest(GUIContent @NotNull ... contents) { + return (DataGUI) super.setNorthWest(contents); + } + + @Override + public @NotNull DataGUI unsetNorthWest() { + return (DataGUI) super.unsetNorthWest(); + } + + @Override + public @NotNull DataGUI setNorth(Item @NotNull ... contents) { + return (DataGUI) super.setNorth(contents); + } + + @Override + public @NotNull DataGUI setNorth(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setNorth(contents); + } + + @Override + public @NotNull DataGUI setNorth(GUIContent @NotNull ... contents) { + return (DataGUI) super.setNorth(contents); + } + + @Override + public @NotNull DataGUI unsetNorth() { + return (DataGUI) super.unsetNorth(); + } + + @Override + public @NotNull DataGUI setNorthEast(Item @NotNull ... contents) { + return (DataGUI) super.setNorthEast(contents); + } + + @Override + public @NotNull DataGUI setNorthEast(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setNorthEast(contents); + } + + @Override + public @NotNull DataGUI setNorthEast(GUIContent @NotNull ... contents) { + return (DataGUI) super.setNorthEast(contents); + } + + @Override + public @NotNull DataGUI unsetNorthEast() { + return (DataGUI) super.unsetNorthEast(); + } + + @Override + public @NotNull DataGUI setMiddleWest(Item @NotNull ... contents) { + return (DataGUI) super.setMiddleWest(contents); + } + + @Override + public @NotNull DataGUI setMiddleWest(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setMiddleWest(contents); + } + + @Override + public @NotNull DataGUI setMiddleWest(GUIContent @NotNull ... contents) { + return (DataGUI) super.setMiddleWest(contents); + } + + @Override + public @NotNull DataGUI unsetMiddleWest() { + return (DataGUI) super.unsetMiddleWest(); + } + + @Override + public @NotNull DataGUI setMiddle(Item @NotNull ... contents) { + return (DataGUI) super.setMiddle(contents); + } + + @Override + public @NotNull DataGUI setMiddle(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setMiddle(contents); + } + + @Override + public @NotNull DataGUI setMiddle(GUIContent @NotNull ... contents) { + return (DataGUI) super.setMiddle(contents); + } + + @Override + public @NotNull DataGUI unsetMiddle() { + return (DataGUI) super.unsetMiddle(); + } + + @Override + public @NotNull DataGUI setMiddleEast(Item @NotNull ... contents) { + return (DataGUI) super.setMiddleEast(contents); + } + + @Override + public @NotNull DataGUI setMiddleEast(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setMiddleEast(contents); + } + + @Override + public @NotNull DataGUI setMiddleEast(GUIContent @NotNull ... contents) { + return (DataGUI) super.setMiddleEast(contents); + } + + @Override + public @NotNull DataGUI unsetMiddleEast() { + return (DataGUI) super.unsetMiddleEast(); + } + + @Override + public @NotNull DataGUI setSouthWest(Item @NotNull ... contents) { + return (DataGUI) super.setSouthWest(contents); + } + + @Override + public @NotNull DataGUI setSouthWest(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setSouthWest(contents); + } + + @Override + public @NotNull DataGUI setSouthWest(GUIContent @NotNull ... contents) { + return (DataGUI) super.setSouthWest(contents); + } + + @Override + public @NotNull DataGUI unsetSouthWest() { + return (DataGUI) super.unsetSouthWest(); + } + + @Override + public @NotNull DataGUI setSouth(Item @NotNull ... contents) { + return (DataGUI) super.setSouth(contents); + } + + @Override + public @NotNull DataGUI setSouth(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setSouth(contents); + } + + @Override + public @NotNull DataGUI setSouth(GUIContent @NotNull ... contents) { + return (DataGUI) super.setSouth(contents); + } + + @Override + public @NotNull DataGUI unsetSouth() { + return (DataGUI) super.unsetSouth(); + } + + @Override + public @NotNull DataGUI setSouthEast(Item @NotNull ... contents) { + return (DataGUI) super.setSouthEast(contents); + } + + @Override + public @NotNull DataGUI setSouthEast(ItemGUIContent @NotNull ... contents) { + return (DataGUI) super.setSouthEast(contents); + } + + @Override + public @NotNull DataGUI setSouthEast(GUIContent @NotNull ... contents) { + return (DataGUI) super.setSouthEast(contents); + } + + @Override + public @NotNull DataGUI unsetSouthEast() { + return (DataGUI) super.unsetSouthEast(); + } + + @Override + public @NotNull DataGUI clear() { + return (DataGUI) super.clear(); + } + + @Override + public @NotNull DataGUI onClickOutside(@NotNull String command) { + return (DataGUI) super.onClickOutside(command); + } + + @Override + public @NotNull DataGUI onOpenGUI(@NotNull String command) { + return (DataGUI) super.onOpenGUI(command); + } + + @Override + public @NotNull DataGUI onCloseGUI(@NotNull String command) { + return (DataGUI) super.onCloseGUI(command); + } + + @Override + public @NotNull DataGUI onChangeGUI(@NotNull String command) { + return (DataGUI) super.onChangeGUI(command); + } + + @Override + public @NotNull DataGUI setVariable(@NotNull String name, @NotNull String value) { + return (DataGUI) super.setVariable(name, value); + } + + @Override + public @NotNull DataGUI unsetVariable(@NotNull String name) { + return (DataGUI) super.unsetVariable(name); + } + + @Override + public @NotNull DataGUI copyAll(@NotNull GUI other, boolean replace) { + return (DataGUI) super.copyAll(other, replace); + } + + @Override + public @NotNull DataGUI copyFrom(@NotNull GUI other, boolean replace) { + return (DataGUI) super.copyFrom(other, replace); + } + + @Override + public DataGUI copy() { + return (DataGUI) super.copy(); + } + + @Override + public @NotNull DataGUI copyAll(@NotNull Metadatable other, boolean replace) { + return (DataGUI) super.copyAll(other, replace); + } + + @Override + public @NotNull DataGUI copyFrom(@NotNull Metadatable other, boolean replace) { + return (DataGUI) super.copyFrom(other, replace); + } + /** * Creates a new {@link DataGUI} with the given size and converter. * From 037f430715455df853859f70754e25c5b49d1714 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:30:26 +0200 Subject: [PATCH 157/204] Increased tests efficacy with map object --- .../java/it/angrybear/yagl/utils/ObjectUtilsTest.java | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/common/base/src/test/java/it/angrybear/yagl/utils/ObjectUtilsTest.java b/common/base/src/test/java/it/angrybear/yagl/utils/ObjectUtilsTest.java index 95f0ddcb..2fac9414 100644 --- a/common/base/src/test/java/it/angrybear/yagl/utils/ObjectUtilsTest.java +++ b/common/base/src/test/java/it/angrybear/yagl/utils/ObjectUtilsTest.java @@ -3,9 +3,7 @@ import org.jetbrains.annotations.NotNull; import org.junit.jupiter.api.Test; -import java.util.Arrays; -import java.util.Iterator; -import java.util.List; +import java.util.*; import static org.junit.jupiter.api.Assertions.*; @@ -36,6 +34,10 @@ void testCopyOfData() { assertNotEquals(c1.array, c2.array); assertArrayEquals(c1.array, c2.array); assertNotEquals(c1.copiable, c2.copiable); + assertEquals(c1.map, c2.map); + // Try removal from the first map + c1.map.remove("hello"); + assertEquals("world", c2.map.get("hello")); } @Test @@ -46,6 +48,9 @@ void testCopyThrowsIllegalArgument() { } private static class GeneralCopy { + Map map = new HashMap(){{ + put("hello", "world"); + }}; List list = Arrays.asList("hello", "world"); String[] array = new String[]{"hello", "world"}; GeneralCopiable copiable = new GeneralCopiable(); From 818e7148af3682ea8dc160b2f589c79d00563d7b Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:34:08 +0200 Subject: [PATCH 158/204] Added tests for copy method --- .../java/it/angrybear/yagl/guis/GUIImplTest.java | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/GUIImplTest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/GUIImplTest.java index 48b03c48..dbffae5c 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/GUIImplTest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/GUIImplTest.java @@ -7,6 +7,7 @@ import it.angrybear.yagl.items.Item; import it.angrybear.yagl.viewers.Viewer; import it.angrybear.yagl.wrappers.Sound; +import it.fulminazzo.fulmicollection.objects.Refl; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; import org.junit.jupiter.api.BeforeEach; @@ -224,6 +225,20 @@ void testEqualsDifferentObjects() { assertNotEquals(c1, ItemGUIContent.newInstance("grass")); } + @Test + void testCopy() { + GUIImpl.Contents c1 = new GUIImpl.Contents( + ItemGUIContent.newInstance("stone"), + ItemGUIContent.newInstance("grass"), + null + ); + GUIImpl.Contents c2 = c1.copy(); + assertEquals(c1.getContents(), c2.getContents()); + Object cs1 = new Refl<>(c1).getFieldRefl("contents"); + Object cs2 = new Refl<>(c2).getFieldRefl("contents"); + assertNotEquals(cs1.hashCode(), cs2.hashCode()); + } + } public static class MockGUI extends GUIImpl { From 10336df14adbbb34701dc200898e558b5ef82ca6 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:41:15 +0200 Subject: [PATCH 159/204] Added tests for constructors --- .../it/angrybear/yagl/guis/DataGUITest.java | 26 +++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 4269d2cf..e65c082b 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -13,6 +13,7 @@ import org.junit.jupiter.params.provider.MethodSource; import org.mockito.MockedStatic; +import java.util.Arrays; import java.util.List; import java.util.UUID; import java.util.function.Function; @@ -128,4 +129,29 @@ void testReturnTypes() { TestUtils.testReturnType(DataGUI.newGUI(9, c -> null), GUI.class, m -> m.getName().equals("copy")); } + private static Object[][] constructorParameters() { + return new Object[][]{ + new Object[]{27, null, null}, + new Object[]{27, null, new Object[]{"Hello", "World"}}, + new Object[]{27, null, Arrays.asList("Hello", "World")}, + new Object[]{GUIType.CHEST, null, null}, + new Object[]{GUIType.CHEST, null, new Object[]{"Hello", "World"}}, + new Object[]{GUIType.CHEST, null, Arrays.asList("Hello", "World")}, + }; + } + + @ParameterizedTest + @MethodSource("constructorParameters") + void testConstructors(Object obj1, Object obj2, Object obj3) { + @NotNull DataGUI expected = obj1 instanceof GUIType ? + new DataGUI<>(GUIType.CHEST, null) : + new DataGUI<>(27, null); + expected.setData("Hello", "World"); + DataGUI actual; + if (obj3 == null) { + actual = new Refl<>(DataGUI.class).invokeMethod("newGUI", obj1, obj2); + actual.setData("Hello", "World"); + } else actual = new Refl<>(DataGUI.class).invokeMethod("newGUI", obj1, obj2, obj3); + assertEquals(expected, actual); + } } \ No newline at end of file From efe1c1d464ce1819684e820a61296d2261ed665a Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Thu, 18 Apr 2024 23:43:42 +0200 Subject: [PATCH 160/204] Updated return types tests --- .../src/test/java/it/angrybear/yagl/guis/DataGUITest.java | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index e65c082b..fff5d896 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -126,7 +126,11 @@ void testOpenPage() { @Test void testReturnTypes() { - TestUtils.testReturnType(DataGUI.newGUI(9, c -> null), GUI.class, m -> m.getName().equals("copy")); + TestUtils.testReturnType(DataGUI.newGUI(9, c -> null), PageableGUI.class, m -> { + for (String s : Arrays.asList("copy", "setPages", "getPage")) + if (s.equals(m.getName())) return true; + return false; + }); } private static Object[][] constructorParameters() { From 690c4906e8f2e24fa81e9cf102aada35333eb988 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 01:45:22 +0200 Subject: [PATCH 161/204] Added tests for pages related methods --- .../test/java/it/angrybear/yagl/guis/DataGUITest.java | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index fff5d896..008f4c95 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -11,6 +11,7 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.params.ParameterizedTest; import org.junit.jupiter.params.provider.MethodSource; +import org.junit.jupiter.params.provider.ValueSource; import org.mockito.MockedStatic; import java.util.Arrays; @@ -73,6 +74,14 @@ void testPagesMethod(int contents, int data, int expected) { assertEquals(expected, pages); } + @ParameterizedTest + @ValueSource(strings = {"getPage", "setPages"}) + void testPagesRelatedMethodShouldThrowException(String method) { + Throwable throwable = assertThrowsExactly(IllegalStateException.class, () -> + new Refl<>(DataGUI.newGUI(GUIType.ANVIL, s -> null)).invokeMethod(method, 1)); + assertEquals(new Refl<>(DataGUI.class).getFieldObject("ERROR_MESSAGE"), throwable.getMessage()); + } + @Test void testOpenPage() { int[][] slots = new int[][]{ From eeb9340449a54548a6ab7124bb9ab4c5ac49ba87 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 01:47:18 +0200 Subject: [PATCH 162/204] Added tests for open invalid page --- .../test/java/it/angrybear/yagl/guis/DataGUITest.java | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 008f4c95..fd2b48f0 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -63,6 +63,17 @@ void testFillContentsMethod(int contents, int data, int pages) { } } + @Test + void testInvalidPage() { + DataGUI gui = DataGUI.newGUI(9, s -> null).setData(new String[]{"Hello"}); + int page = 3; + Throwable throwable = assertThrowsExactly(IllegalArgumentException.class, () -> + gui.open(null, page)); + String message = throwable.getMessage(); + assertTrue(message.contains(String.valueOf(page)), + String.format("Message should contain '%s' but was '%s'", page, message)); + } + @ParameterizedTest @MethodSource("pagesTest") void testPagesMethod(int contents, int data, int expected) { From b540583a755ffcf9106ce77b449a51b2927bf839 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 01:48:31 +0200 Subject: [PATCH 163/204] Added tests for no empty slots available --- .../test/java/it/angrybear/yagl/guis/DataGUITest.java | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index fd2b48f0..72fc9b25 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -74,6 +74,15 @@ void testInvalidPage() { String.format("Message should contain '%s' but was '%s'", page, message)); } + @Test + void testNoEmptySlots() { + int size = 9; + Item[] contents = new Item[size]; + Arrays.fill(contents, Item.newItem("stone")); + DataGUI gui = DataGUI.newGUI(size, s -> null).addContent(contents); + assertThrowsExactly(IllegalStateException.class, gui::pages); + } + @ParameterizedTest @MethodSource("pagesTest") void testPagesMethod(int contents, int data, int expected) { From c518c1ccb973171cb555b892ecdca7f3506126fd Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 01:50:35 +0200 Subject: [PATCH 164/204] Added getData method --- gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java | 2 ++ 1 file changed, 2 insertions(+) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index c6a1e98f..11dbd877 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -7,6 +7,7 @@ import it.angrybear.yagl.contents.ItemGUIContent; import it.angrybear.yagl.items.Item; import it.angrybear.yagl.viewers.Viewer; +import lombok.Getter; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; @@ -26,6 +27,7 @@ public class DataGUI extends PageableGUI { private static final String ERROR_MESSAGE = "Pages are dynamically calculated when opening this GUI. They cannot be singly edited"; + @Getter private final @NotNull List data; private final @NotNull Function dataConverter; From 50733eb7c225f0702432fae7a7692c3d8f51c18d Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 01:55:01 +0200 Subject: [PATCH 165/204] Fixed removeData(Collection) method --- gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 11dbd877..1f8ec7bd 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -11,10 +11,7 @@ import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; -import java.util.Arrays; -import java.util.Collection; -import java.util.LinkedList; -import java.util.List; +import java.util.*; import java.util.function.Function; import java.util.function.Predicate; @@ -113,7 +110,7 @@ public class DataGUI extends PageableGUI { * @return this gui */ public @NotNull DataGUI removeData(final @NotNull Collection data) { - return removeData(t -> t.equals(data)); + return removeData(t -> data.stream().anyMatch(c -> Objects.equals(c, t))); } /** From c8bfdc00ec5575082c25005e7a7c79f10377eac4 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 01:57:35 +0200 Subject: [PATCH 166/204] Added tests for removeData methods --- .../it/angrybear/yagl/guis/DataGUITest.java | 20 +++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 72fc9b25..96cc353b 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -18,6 +18,7 @@ import java.util.List; import java.util.UUID; import java.util.function.Function; +import java.util.function.Predicate; import static org.junit.jupiter.api.Assertions.*; import static org.mockito.Mockito.CALLS_REAL_METHODS; @@ -63,6 +64,25 @@ void testFillContentsMethod(int contents, int data, int pages) { } } + private static Object[] removeDataParameters() { + return new Object[]{ + "hello,world", + Arrays.asList("hello", "world"), + (Predicate) s -> s.equals("hello") || s.equals("world") + }; + } + + @ParameterizedTest + @MethodSource("removeDataParameters") + void testRemoveData(Object object) { + if (object instanceof String) + object = Arrays.stream(object.toString().split(",")).toArray(Object[]::new); + DataGUI gui = DataGUI.newGUI(9, s -> null, "hello", "world"); + new Refl<>(gui).invokeMethod("removeData", object); + @NotNull List data = gui.getData(); + assertTrue(data.isEmpty(), String.format("Expected empty but was '%s'", data)); + } + @Test void testInvalidPage() { DataGUI gui = DataGUI.newGUI(9, s -> null).setData(new String[]{"Hello"}); From 7218af29768da37f4df9d56ff421c2ed41c71a21 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 02:02:26 +0200 Subject: [PATCH 167/204] Added tests for previous and next page items --- .../it/angrybear/yagl/guis/DataGUITest.java | 49 +++++++++++-------- 1 file changed, 28 insertions(+), 21 deletions(-) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 96cc353b..846d790a 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -28,23 +28,23 @@ class DataGUITest { private static Object[][] pagesTest() { return new Object[][]{ - new Object[]{0, 27, 1}, - new Object[]{0, 54, 2}, - new Object[]{9, 54, 3}, - new Object[]{26, 54, 54}, - new Object[]{14, 198, 16}, + new Object[]{0, 27, 1, false, false}, + new Object[]{0, 54, 2, false, false}, + new Object[]{9, 54, 3, false, false}, + new Object[]{26, 54, 54, false, false}, + new Object[]{14, 198, 16, false, false}, + new Object[]{0, 27, 2, false, true}, + new Object[]{0, 27, 1, true, false}, + new Object[]{0, 54, 3, true, true}, }; } @ParameterizedTest @MethodSource("pagesTest") - void testFillContentsMethod(int contents, int data, int pages) { + void testFillContentsMethod(int contents, int data, int pages, boolean prev, boolean next) { GUIContent convertedContent = ItemGUIContent.newInstance("grass"); - DataGUI dataGUI = DataGUI.newGUI(27, s -> convertedContent); + DataGUI dataGUI = setupGUI(contents, data, prev, next, convertedContent); Refl guiRefl = new Refl<>(dataGUI); - for (int i = 0; i < data; i++) dataGUI.addData(i); - @NotNull Item stone = Item.newItem("stone"); - for (int i = 0; i < contents; i++) dataGUI.addContent(stone); for (int p = 0; p < pages; p++) { GUI gui = guiRefl.getFieldObject("templateGUI"); @@ -64,6 +64,24 @@ void testFillContentsMethod(int contents, int data, int pages) { } } + @ParameterizedTest + @MethodSource("pagesTest") + void testPagesMethod(int contents, int data, int expected, boolean prev, boolean next) { + DataGUI dataGUI = setupGUI(contents, data, prev, next, ItemGUIContent.newInstance()); + int pages = dataGUI.pages(); + assertEquals(expected, pages); + } + + private static @NotNull DataGUI setupGUI(int contents, int data, boolean prev, boolean next, GUIContent convertedContent) { + DataGUI dataGUI = DataGUI.newGUI(27, s -> convertedContent); + if (prev) dataGUI.setPreviousPage(0, Item.newItem()); + if (next) dataGUI.setNextPage(0, Item.newItem()); + for (int i = 0; i < data; i++) dataGUI.addData(i); + @NotNull Item stone = Item.newItem("stone"); + for (int i = 0; i < contents; i++) dataGUI.addContent(stone); + return dataGUI; + } + private static Object[] removeDataParameters() { return new Object[]{ "hello,world", @@ -103,17 +121,6 @@ void testNoEmptySlots() { assertThrowsExactly(IllegalStateException.class, gui::pages); } - @ParameterizedTest - @MethodSource("pagesTest") - void testPagesMethod(int contents, int data, int expected) { - DataGUI dataGUI = DataGUI.newGUI(27, s -> ItemGUIContent.newInstance()); - for (int i = 0; i < data; i++) dataGUI.addData(i); - for (int i = 0; i < contents; i++) dataGUI.addContent(Item.newItem("stone")); - - int pages = dataGUI.pages(); - assertEquals(expected, pages); - } - @ParameterizedTest @ValueSource(strings = {"getPage", "setPages"}) void testPagesRelatedMethodShouldThrowException(String method) { From 852842627d67b9f71b66f5706baead844fbf426f Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 02:08:09 +0200 Subject: [PATCH 168/204] Reworked emptySlots method to exclude previous and next slots --- .../main/java/it/angrybear/yagl/guis/DataGUI.java | 2 -- .../java/it/angrybear/yagl/guis/PageableGUI.java | 15 +++++++++++++++ 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 1f8ec7bd..c09a61ac 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -141,8 +141,6 @@ public void open(@NotNull Viewer viewer, int page) { private @NotNull GUI fillContents(final @NotNull GUI gui, final int page) { int emptySlots = emptySlots().size(); - if (this.previousPage.isPresent()) emptySlots--; - if (this.nextPage.isPresent()) emptySlots--; int min = emptySlots * page; if (min >= this.data.size()) throw new IllegalArgumentException(String.format("No such page '%s'", page)); diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java index ccdd0e29..6bc008d2 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java @@ -212,6 +212,21 @@ public void open(final @NotNull Viewer viewer, final int page) { return newGUI; } + /** + * Counts the empty slots of the current GUI. + * If {@link #setPreviousPage(int, GUIContent)} or {@link #setNextPage(int, GUIContent)} + * were used, their slots are removed from the final count. + * + * @return the slots + */ + @Override + public @NotNull Set emptySlots() { + final Set slots = GUI.super.emptySlots(); + this.previousPage.ifPresent((i, p) -> slots.remove(i)); + this.nextPage.ifPresent((i, p) -> slots.remove(i)); + return slots; + } + @Override public @NotNull PageableGUI setTitle(final @Nullable String title) { this.templateGUI.setTitle(title); From a6841ddcfb81042dfc37a26068cca54c5e4ede01 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 02:16:27 +0200 Subject: [PATCH 169/204] Reworked pages method --- .../java/it/angrybear/yagl/guis/DataGUI.java | 32 +++++++++++-------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index c09a61ac..8110ff2c 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -161,24 +161,28 @@ public void open(@NotNull Viewer viewer, int page) { */ @Override public int pages() { - int emptySlots = emptySlots().size(); + final int emptySlots = emptySlots().size(); + //TODO: not counting 1 item nextPage if (emptySlots == 0) throw new IllegalStateException("Cannot set data for non-empty pages"); - int size = this.data.size(); - int pages = size % emptySlots == 0 ? 0 : 1; - if (size < emptySlots) return pages; - int add = 0; - if (this.previousPage.isPresent()) { - pages++; - size -= emptySlots - (this.nextPage.isEmpty() ? 1 : 0); - add--; - } - if (this.nextPage.isPresent()) { + int dataSize = this.data.size(); + // Start counting first page. + int firstPageSlots = emptySlots; + if (this.previousPage.isPresent()) firstPageSlots++; + dataSize -= firstPageSlots; + int pages = 1; + if (dataSize < 1) return pages; + // Count final page + int finalPageSlots = emptySlots; + if (this.nextPage.isPresent()) finalPageSlots++; + dataSize -= finalPageSlots; + pages++; + if (dataSize < 0) return pages; + // Count remaining pages + while (dataSize > 0) { pages++; - size -= emptySlots + add; - add--; + dataSize -= emptySlots; } - while ((size -= emptySlots + add) >= 0) pages++; return pages; } From aa757d7622eeb6a4f8911111706b8df352bdc6a5 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 02:18:18 +0200 Subject: [PATCH 170/204] Updated setupGUI to put pages buttons in different slots --- .../it/angrybear/yagl/guis/DataGUITest.java | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 846d790a..039eda2c 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -39,6 +39,14 @@ private static Object[][] pagesTest() { }; } + @ParameterizedTest + @MethodSource("pagesTest") + void testPagesMethod(int contents, int data, int expected, boolean prev, boolean next) { + DataGUI dataGUI = setupGUI(contents, data, prev, next, ItemGUIContent.newInstance()); + int pages = dataGUI.pages(); + assertEquals(expected, pages); + } + @ParameterizedTest @MethodSource("pagesTest") void testFillContentsMethod(int contents, int data, int pages, boolean prev, boolean next) { @@ -64,18 +72,10 @@ void testFillContentsMethod(int contents, int data, int pages, boolean prev, boo } } - @ParameterizedTest - @MethodSource("pagesTest") - void testPagesMethod(int contents, int data, int expected, boolean prev, boolean next) { - DataGUI dataGUI = setupGUI(contents, data, prev, next, ItemGUIContent.newInstance()); - int pages = dataGUI.pages(); - assertEquals(expected, pages); - } - private static @NotNull DataGUI setupGUI(int contents, int data, boolean prev, boolean next, GUIContent convertedContent) { DataGUI dataGUI = DataGUI.newGUI(27, s -> convertedContent); if (prev) dataGUI.setPreviousPage(0, Item.newItem()); - if (next) dataGUI.setNextPage(0, Item.newItem()); + if (next) dataGUI.setNextPage(2, Item.newItem()); for (int i = 0; i < data; i++) dataGUI.addData(i); @NotNull Item stone = Item.newItem("stone"); for (int i = 0; i < contents; i++) dataGUI.addContent(stone); From 45f6a236e5a9cddf491436bebdee0309b4b86d89 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 02:21:14 +0200 Subject: [PATCH 171/204] Added private constructor for copy method --- gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 8110ff2c..f997a422 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -28,6 +28,11 @@ public class DataGUI extends PageableGUI { private final @NotNull List data; private final @NotNull Function dataConverter; + private DataGUI() { + this.data = new LinkedList<>(); + this.dataConverter = t -> null; + } + /** * Instantiates a new Data gui. * From 3e7aa16c9079d9c9ba48b74383601d53f61c9666 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 02:21:21 +0200 Subject: [PATCH 172/204] Added tests for copy method --- .../src/test/java/it/angrybear/yagl/guis/DataGUITest.java | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 039eda2c..9da2434d 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -189,6 +189,13 @@ void testReturnTypes() { }); } + @Test + void testCopy() { + DataGUI expected = DataGUI.newGUI(9, c -> null, "Hello", "world"); + DataGUI actual = expected.copy(); + assertEquals(expected, actual); + } + private static Object[][] constructorParameters() { return new Object[][]{ new Object[]{27, null, null}, From 6d18c63681ad4433c6f532bb2f49037a5c65d1f2 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 02:23:07 +0200 Subject: [PATCH 173/204] Reworked constructor --- gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index f997a422..25741da0 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -28,9 +28,11 @@ public class DataGUI extends PageableGUI { private final @NotNull List data; private final @NotNull Function dataConverter; + @SuppressWarnings("DataFlowIssue") private DataGUI() { this.data = new LinkedList<>(); - this.dataConverter = t -> null; + // Temporary value replaced by Field set. + this.dataConverter = null; } /** From 0a62fbbc825208cf007acf79989f39dd411c8374 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 11:10:20 +0200 Subject: [PATCH 174/204] Updated tests --- gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 9da2434d..097328a0 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -117,7 +117,7 @@ void testNoEmptySlots() { int size = 9; Item[] contents = new Item[size]; Arrays.fill(contents, Item.newItem("stone")); - DataGUI gui = DataGUI.newGUI(size, s -> null).addContent(contents); + DataGUI gui = DataGUI.newGUI(size, s -> null, "Hello").addContent(contents); assertThrowsExactly(IllegalStateException.class, gui::pages); } From aba0d1f542d4a22f3c243fd1bd0d293d5e79af9d Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 11:10:39 +0200 Subject: [PATCH 175/204] Reworked pages method to check for previous and next page buttons --- .../java/it/angrybear/yagl/guis/DataGUI.java | 60 ++++++++++++++----- 1 file changed, 46 insertions(+), 14 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 25741da0..d4ca5aeb 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -161,6 +161,40 @@ public void open(@NotNull Viewer viewer, int page) { return gui; } + /** + * Gets the first page empty slots. + * + * @return the slots + */ + protected int getFirstPageEmptySlots() { + int slots = getPageEmptySlots(); + if (this.previousPage.isPresent()) slots++; + return slots; + } + + /** + * Gets the last page empty slots. + * + * @return the slots + */ + protected int getLastPageEmptySlots() { + int slots = getPageEmptySlots(); + if (this.nextPage.isPresent()) slots++; + return slots; + } + + /** + * Gets a general page empty slots. + * + * @return the slots + */ + protected int getPageEmptySlots() { + final Set slots = emptySlots(); + this.previousPage.ifPresent((i, p) -> slots.remove(i)); + this.nextPage.ifPresent((i, p) -> slots.remove(i)); + return slots.size(); + } + /** * Gets the number of pages based on the amount of data provided. * @@ -168,24 +202,22 @@ public void open(@NotNull Viewer viewer, int page) { */ @Override public int pages() { - final int emptySlots = emptySlots().size(); - //TODO: not counting 1 item nextPage - if (emptySlots == 0) - throw new IllegalStateException("Cannot set data for non-empty pages"); int dataSize = this.data.size(); - // Start counting first page. - int firstPageSlots = emptySlots; - if (this.previousPage.isPresent()) firstPageSlots++; - dataSize -= firstPageSlots; + if (dataSize == 0) throw new IllegalArgumentException("Cannot set empty data"); + final int emptySlots = getPageEmptySlots(); + final int firstPageSlots = getFirstPageEmptySlots(); + final int lastPageSlots = getLastPageEmptySlots(); int pages = 1; + // First page + dataSize -= firstPageSlots; if (dataSize < 1) return pages; - // Count final page - int finalPageSlots = emptySlots; - if (this.nextPage.isPresent()) finalPageSlots++; - dataSize -= finalPageSlots; + if (emptySlots < 1) + throw new IllegalStateException(String.format("Not enough empty slots available to set %s items of data", dataSize)); + // Last page pages++; - if (dataSize < 0) return pages; - // Count remaining pages + dataSize -= lastPageSlots; + if (dataSize < 1) return pages; + // Other pages while (dataSize > 0) { pages++; dataSize -= emptySlots; From d594aeb74cda4dd4941f098f3805f1bf6d512052 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 12:28:57 +0200 Subject: [PATCH 176/204] Added filter for lambda objects in apply method --- gui/base/src/main/java/it/angrybear/yagl/Metadatable.java | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java b/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java index 01de39a6..2406863f 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java +++ b/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java @@ -124,14 +124,17 @@ default boolean hasVariable(final @NotNull String name) { default T apply(final T object) { if (object == null) return null; else if (object.getClass().isEnum()) return object; + else if (object.getClass().isInterface()) return object; else if (object instanceof String) return (T) apply((String) object); else if (object instanceof Collection) return (T) apply((Collection) object); else if (object instanceof Map) return (T) apply((Map) object); else if (!ReflectionUtils.isPrimitiveOrWrapper(object.getClass())) { final Refl refl = new Refl<>(object); for (Field field : refl.getNonStaticFields()) - ReflectionUtils.setAccessible(field).ifPresent(f -> - refl.setFieldObject(f, apply(f.get(object)))); + ReflectionUtils.setAccessible(field) + .map(f -> f.get(object)) + .filter(o -> !o.toString().contains("Lambda")) + .ifPresent(o -> field.set(object, apply(o))); } return object; } From 67e31e58f73c02c1b0ce8533ed4523f60ee5dc41 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 12:40:41 +0200 Subject: [PATCH 177/204] Reworked openGUI test to prevent deadlock --- .../src/test/java/it/angrybear/yagl/GUIAdapterTest.java | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java b/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java index 654b4c85..40ee374f 100644 --- a/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java +++ b/gui/bukkit/src/test/java/it/angrybear/yagl/GUIAdapterTest.java @@ -26,6 +26,7 @@ import java.util.List; import java.util.UUID; +import java.util.concurrent.atomic.AtomicBoolean; import static org.junit.jupiter.api.Assertions.*; import static org.mockito.Mockito.*; @@ -140,10 +141,11 @@ void testCloseGUIForOfflinePlayer() { @Test void testOpenGUIAction() { GUI gui = GUI.newGUI(9); - GUIAction openAction = mock(GUIAction.class); + AtomicBoolean executed = new AtomicBoolean(false); + GUIAction openAction = (g, v) -> executed.set(true); gui.onOpenGUI(openAction); openGUI(gui); - verify(openAction).execute(GUIManager.getViewer(this.player), gui); + assertTrue(executed.get(), "openAction was not executed"); } private void openGUI(GUI gui) { From ac132abc05ea5d5607dfac515c38d1b868fcc5b5 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 12:50:48 +0200 Subject: [PATCH 178/204] Added tests for no data provided --- .../src/test/java/it/angrybear/yagl/guis/DataGUITest.java | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 097328a0..3928daa5 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -101,6 +101,13 @@ void testRemoveData(Object object) { assertTrue(data.isEmpty(), String.format("Expected empty but was '%s'", data)); } + @Test + void testNoData() { + DataGUI gui = DataGUI.newGUI(9, s -> null); + int page = 3; + assertThrowsExactly(IllegalArgumentException.class, () -> gui.open(null, page)); + } + @Test void testInvalidPage() { DataGUI gui = DataGUI.newGUI(9, s -> null).setData(new String[]{"Hello"}); From 0a323d9730f8e2b665790afff0824c53e7185fb5 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 12:51:27 +0200 Subject: [PATCH 179/204] Removed unused check for interface --- gui/base/src/main/java/it/angrybear/yagl/Metadatable.java | 1 - 1 file changed, 1 deletion(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java b/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java index 2406863f..db5f48c6 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java +++ b/gui/base/src/main/java/it/angrybear/yagl/Metadatable.java @@ -124,7 +124,6 @@ default boolean hasVariable(final @NotNull String name) { default T apply(final T object) { if (object == null) return null; else if (object.getClass().isEnum()) return object; - else if (object.getClass().isInterface()) return object; else if (object instanceof String) return (T) apply((String) object); else if (object instanceof Collection) return (T) apply((Collection) object); else if (object instanceof Map) return (T) apply((Map) object); From e64bd778b667c27dc9a4c1466eadc4a4706057b7 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 13:20:19 +0200 Subject: [PATCH 180/204] Extracted getObjectFromType method --- .../angrybear/yagl/parsers/TypedParser.java | 28 +++++++++++++++---- 1 file changed, 22 insertions(+), 6 deletions(-) diff --git a/common/serializer/src/main/java/it/angrybear/yagl/parsers/TypedParser.java b/common/serializer/src/main/java/it/angrybear/yagl/parsers/TypedParser.java index 68b15cfb..e09033ec 100644 --- a/common/serializer/src/main/java/it/angrybear/yagl/parsers/TypedParser.java +++ b/common/serializer/src/main/java/it/angrybear/yagl/parsers/TypedParser.java @@ -3,9 +3,11 @@ import it.angrybear.yagl.utils.ParserUtils; import it.fulminazzo.fulmicollection.interfaces.functions.TriConsumer; import it.fulminazzo.fulmicollection.objects.Refl; +import it.fulminazzo.yamlparser.configuration.ConfigurationSection; import it.fulminazzo.yamlparser.configuration.IConfiguration; import it.fulminazzo.yamlparser.parsers.CallableYAMLParser; import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; /** * This parser allows parsing an object using the {@link CallableYAMLParser} methods. @@ -23,12 +25,7 @@ public abstract class TypedParser extends CallableYAMLParser { * @param clazz the clazz */ public TypedParser(final @NotNull Class clazz) { - super(clazz, (c) -> { - String type = c.getString(TYPE_FIELD); - if (type == null) throw new IllegalArgumentException(String.format("'%s' cannot be null", TYPE_FIELD)); - Class clz = ParserUtils.typeToClass(clazz, type); - return new Refl<>(clz, new Object[0]).getObject(); - }); + super(clazz, c -> getObjectFromType(clazz, c)); } @SuppressWarnings("unchecked") @@ -40,4 +37,23 @@ protected TriConsumer getDumper() { c.set(s + "." + TYPE_FIELD, ParserUtils.classToType(getOClass(), (Class) g.getClass())); }; } + + /** + * Tries to get the corresponding {@link #TYPE_FIELD} type from the given section, and coverts it to an instance. + * Throws an {@link IllegalArgumentException} in case no type is provided or no class is found. + * + * @param the type of the object + * @param objectClass the object class + * @param section the section + * @param parameters the parameters for the constructor + * @return the object + */ + protected static T getObjectFromType(final @NotNull Class objectClass, + final @NotNull ConfigurationSection section, + final Object @Nullable ... parameters) { + String type = section.getString(TYPE_FIELD); + if (type == null) throw new IllegalArgumentException(String.format("'%s' cannot be null", TYPE_FIELD)); + Class clazz = ParserUtils.typeToClass(objectClass, type); + return new Refl<>(clazz, parameters).getObject(); + } } From a5d61073515f0261a1ff5cb3ba22e2a66b7a890f Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 13:24:02 +0200 Subject: [PATCH 181/204] Reworked PageableGUIParser to accept different types of PageableGUIs --- .../java/it/angrybear/yagl/parsers/PageableGUIParser.java | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java index d90ed7db..057c293a 100644 --- a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java +++ b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java @@ -10,7 +10,6 @@ import it.fulminazzo.fulmicollection.structures.tuples.Tuple; import it.fulminazzo.yamlparser.configuration.ConfigurationSection; import it.fulminazzo.yamlparser.configuration.IConfiguration; -import it.fulminazzo.yamlparser.parsers.YAMLParser; import org.jetbrains.annotations.NotNull; import java.util.LinkedList; @@ -22,7 +21,7 @@ * A parser to serialize {@link PageableGUI}. */ @SuppressWarnings("DataFlowIssue") -public class PageableGUIParser extends YAMLParser { +public class PageableGUIParser extends TypedParser { private static final String[] IGNORE_FIELDS = new String[]{"type", "size"}; /** @@ -41,7 +40,8 @@ protected BiFunctionException getLoader() { if (size == null) throw new IllegalArgumentException("'size' cannot be null"); Integer pages = section.getInteger("pages"); if (pages == null) throw new IllegalArgumentException("'pages' cannot be null"); - final PageableGUI gui = PageableGUI.newGUI(size).setPages(pages); + final PageableGUI gui = (PageableGUI) getObjectFromType(GUI.class, section, size); + gui.setPages(pages); final Refl refl = new Refl<>(gui); final String guiType = section.getString("gui-type"); From 9841772d0f90c43e3f67d489608db152e9386427 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 13:27:34 +0200 Subject: [PATCH 182/204] Added tests for DataGUI parsing --- .../yagl/parsers/DataGUIParserTest.java | 63 +++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 gui/serializer/src/test/java/it/angrybear/yagl/parsers/DataGUIParserTest.java diff --git a/gui/serializer/src/test/java/it/angrybear/yagl/parsers/DataGUIParserTest.java b/gui/serializer/src/test/java/it/angrybear/yagl/parsers/DataGUIParserTest.java new file mode 100644 index 00000000..63d7736d --- /dev/null +++ b/gui/serializer/src/test/java/it/angrybear/yagl/parsers/DataGUIParserTest.java @@ -0,0 +1,63 @@ +package it.angrybear.yagl.parsers; + +import it.angrybear.yagl.contents.GUIContent; +import it.angrybear.yagl.guis.DataGUI; +import it.angrybear.yagl.guis.GUI; +import it.angrybear.yagl.items.Item; +import it.angrybear.yagl.items.fields.ItemFlag; +import it.fulminazzo.fulmicollection.objects.Refl; +import it.fulminazzo.yamlparser.configuration.FileConfiguration; +import it.fulminazzo.yamlparser.utils.FileUtils; +import org.jetbrains.annotations.NotNull; +import org.junit.jupiter.api.Test; + +import java.io.File; +import java.io.IOException; +import java.util.List; +import java.util.function.Function; + +import static org.junit.jupiter.api.Assertions.*; + +class DataGUIParserTest { + + @Test + void testSaveAndLoadDataGUI() throws IOException { + GUIYAGLParser.addAllParsers(); + Function function = s -> null; + DataGUI expected = DataGUI.newGUI(9, function, "Hello", "world") + .setPreviousPage(1, Item.newItem("paper") + .setDisplayName("&ePrevious Page") + .addEnchantment("unbreaking", 3) + .addItemFlags(ItemFlag.HIDE_UNBREAKABLE)) + .setNextPage(1, Item.newItem("paper") + .setDisplayName("&eNext Page") + .addEnchantment("unbreaking", 3) + .addItemFlags(ItemFlag.HIDE_UNBREAKABLE)) + .setVariable("var1", "hello") + .setVariable("var2", "world"); + GUIParserTest.setupContents(expected); + + File file = new File("build/resources/test/data-gui.yml"); + if (!file.exists()) FileUtils.createNewFile(file); + FileConfiguration configuration = new FileConfiguration(file); + final String path = expected.getClass().getSimpleName().toLowerCase(); + configuration.set(path, expected); + configuration.save(); + + configuration = new FileConfiguration(file); + GUI actual = configuration.get(path, GUI.class); + assertNotNull(actual); + assertInstanceOf(DataGUI.class, actual); + + Refl reflGUI = new Refl<>(actual); + DataGUI dataGUI = (DataGUI) reflGUI + .setFieldObject("dataConverter", function) + .getObject(); + @NotNull List data = dataGUI.getData(); + assertTrue(data.isEmpty(), String.format("Expected empty but was %s", data)); + + reflGUI.setFieldObject("data", expected.getData()); + assertEquals(expected, actual); + } + +} \ No newline at end of file From 01c1acc79080395c3873b067e290004647c4fa47 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 13:30:11 +0200 Subject: [PATCH 183/204] Fixed PageableGUI not using object class for type --- .../main/java/it/angrybear/yagl/parsers/PageableGUIParser.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java index 057c293a..272f54a9 100644 --- a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java +++ b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java @@ -108,7 +108,7 @@ protected TriConsumer getDumper() { c.set(s, refl.getFieldObject("templateGUI")); ConfigurationSection section = c.getConfigurationSection(s); section.set("gui-type", section.getString("type")); - section.set("type", ParserUtils.classToType(GUI.class, getOClass())); + section.set("type", ParserUtils.classToType(GUI.class, p.getClass())); section.set("size", p.size()); section.set("pages", p.pages()); From 92c78892bd24be86b4e8a8771e9b7766c5219c15 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 13:36:25 +0200 Subject: [PATCH 184/204] Updated PageableGUIParser to support DataGUI pages --- .../java/it/angrybear/yagl/parsers/PageableGUIParser.java | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java index 272f54a9..6233cd85 100644 --- a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java +++ b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java @@ -40,8 +40,10 @@ protected BiFunctionException getLoader() { if (size == null) throw new IllegalArgumentException("'size' cannot be null"); Integer pages = section.getInteger("pages"); if (pages == null) throw new IllegalArgumentException("'pages' cannot be null"); - final PageableGUI gui = (PageableGUI) getObjectFromType(GUI.class, section, size); - gui.setPages(pages); + final PageableGUI gui = (PageableGUI) getObjectFromType(GUI.class, section); + try { + gui.setPages(pages); + } catch (IllegalStateException ignored) {} final Refl refl = new Refl<>(gui); final String guiType = section.getString("gui-type"); From 0d07ccd3ee15f8b2cc79a7f4cde9b70466e71b05 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 13:51:30 +0200 Subject: [PATCH 185/204] Fixed GUIParser not getting correct parser for DataGUI --- .../java/it/angrybear/yagl/parsers/GUIParser.java | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/GUIParser.java b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/GUIParser.java index 6640aeeb..fec8c882 100644 --- a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/GUIParser.java +++ b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/GUIParser.java @@ -9,6 +9,7 @@ import it.fulminazzo.yamlparser.configuration.FileConfiguration; import it.fulminazzo.yamlparser.configuration.IConfiguration; import it.fulminazzo.yamlparser.parsers.YAMLParser; +import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; import java.util.List; @@ -31,7 +32,7 @@ protected BiFunctionException getLoader() { ConfigurationSection section = c.getConfigurationSection(s); if (section == null) return null; GUI tmp = new Refl<>(this).getFieldRefl("function").invokeMethod("apply", section); - YAMLParser parser = FileConfiguration.getParser(tmp.getClass()); + YAMLParser parser = getSpecificGUIParser(tmp); if (!parser.equals(this)) return parser.load(c, s); GUI g = super.getLoader().apply(c, s); Integer size = c.getInteger(s + ".size"); @@ -52,7 +53,7 @@ protected TriConsumer getDumper() { return (c, s, g) -> { c.set(s, null); if (g == null) return; - YAMLParser parser = (YAMLParser) FileConfiguration.getParser(g.getClass()); + YAMLParser parser = getSpecificGUIParser(g); if (!this.equals(parser)) parser.dump(c, s, g); else { super.getDumper().accept(c, s, g); @@ -63,4 +64,13 @@ protected TriConsumer getDumper() { }; } + @SuppressWarnings("unchecked") + private YAMLParser getSpecificGUIParser(final @NotNull GUI gui) { + FileConfiguration.removeParsers(this); + YAMLParser parser = FileConfiguration.getParser(gui.getClass()); + FileConfiguration.addParsers(this); + if (parser == null || !getOClass().isAssignableFrom(parser.getOClass())) return this; + return (YAMLParser) parser; + } + } From fdbb7d6ac605702cc2757026c2b1784f0cbb8923 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 13:56:47 +0200 Subject: [PATCH 186/204] Fixed tests types --- .../java/it/angrybear/yagl/parsers/PageableGUIParserTest.java | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/gui/serializer/src/test/java/it/angrybear/yagl/parsers/PageableGUIParserTest.java b/gui/serializer/src/test/java/it/angrybear/yagl/parsers/PageableGUIParserTest.java index 1f124ee8..6aeedddb 100644 --- a/gui/serializer/src/test/java/it/angrybear/yagl/parsers/PageableGUIParserTest.java +++ b/gui/serializer/src/test/java/it/angrybear/yagl/parsers/PageableGUIParserTest.java @@ -89,6 +89,7 @@ void testSizeNotSpecified() { @Test void testPagesNotSpecified() { IConfiguration configuration = getConfiguration(c -> { + c.set("type", "PAGEABLE"); c.set("size", 3); }); Throwable throwable = assertThrowsExactly(IllegalArgumentException.class, () -> @@ -99,6 +100,7 @@ void testPagesNotSpecified() { @Test void testGUITypeNotSpecified() { IConfiguration configuration = getConfiguration(c -> { + c.set("type", "PAGEABLE"); c.set("size", 9); c.set("pages", 3); }); @@ -110,6 +112,7 @@ void testGUITypeNotSpecified() { @Test void testInvalidTemplateGUI() { IConfiguration configuration = getConfiguration(c -> { + c.set("type", "PAGEABLE"); c.set("size", 9); c.set("pages", 3); c.set("gui-type", "DEFAULT"); @@ -153,6 +156,7 @@ void testVariableMaps(Map variables, Object expected) throws Exc doAnswer(a -> variables == null ? null : new HashMap<>(variables)) .when(section).get("variables", Map.class); configuration.toMap().put("gui", section); + section.set("type", "PAGEABLE"); section.set("size", 9); section.set("pages", 3); section.set("gui-type", "DEFAULT"); From bfea48a63f1346a5ab193357b611319280f7e9e0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 13:58:01 +0200 Subject: [PATCH 187/204] Updated Pageable parser not starting with right size --- .../main/java/it/angrybear/yagl/parsers/PageableGUIParser.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java index 6233cd85..73b29f97 100644 --- a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java +++ b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/PageableGUIParser.java @@ -40,7 +40,7 @@ protected BiFunctionException getLoader() { if (size == null) throw new IllegalArgumentException("'size' cannot be null"); Integer pages = section.getInteger("pages"); if (pages == null) throw new IllegalArgumentException("'pages' cannot be null"); - final PageableGUI gui = (PageableGUI) getObjectFromType(GUI.class, section); + final PageableGUI gui = (PageableGUI) getObjectFromType(GUI.class, section, size); try { gui.setPages(pages); } catch (IllegalStateException ignored) {} From 0e1763af541105c44041a2d5d3600018f5d59c16 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 14:00:26 +0200 Subject: [PATCH 188/204] Implemented constructor with size parameter --- .../main/java/it/angrybear/yagl/guis/DataGUI.java | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index d4ca5aeb..2ffe0970 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -5,6 +5,7 @@ import it.angrybear.yagl.actions.GUIAction; import it.angrybear.yagl.contents.GUIContent; import it.angrybear.yagl.contents.ItemGUIContent; +import it.angrybear.yagl.exceptions.NotImplemented; import it.angrybear.yagl.items.Item; import it.angrybear.yagl.viewers.Viewer; import lombok.Getter; @@ -28,11 +29,17 @@ public class DataGUI extends PageableGUI { private final @NotNull List data; private final @NotNull Function dataConverter; - @SuppressWarnings("DataFlowIssue") private DataGUI() { this.data = new LinkedList<>(); - // Temporary value replaced by Field set. - this.dataConverter = null; + this.dataConverter = t -> { + throw new NotImplemented(); + }; + } + + private DataGUI(final int size) { + this(size, t -> { + throw new NotImplemented(); + }); } /** From f10099a4e08a086841b86856bf1b90f9e8e60dc0 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 14:10:13 +0200 Subject: [PATCH 189/204] Added tests for DataGUI private constructors --- .../it/angrybear/yagl/guis/DataGUITest.java | 23 +++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java index 3928daa5..e3d3bb7d 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/DataGUITest.java @@ -4,6 +4,7 @@ import it.angrybear.yagl.actions.GUIItemAction; import it.angrybear.yagl.contents.GUIContent; import it.angrybear.yagl.contents.ItemGUIContent; +import it.angrybear.yagl.exceptions.NotImplemented; import it.angrybear.yagl.items.Item; import it.fulminazzo.fulmicollection.objects.Refl; import it.fulminazzo.fulmicollection.utils.ReflectionUtils; @@ -14,6 +15,9 @@ import org.junit.jupiter.params.provider.ValueSource; import org.mockito.MockedStatic; +import java.lang.reflect.Constructor; +import java.lang.reflect.InvocationTargetException; +import java.lang.reflect.Modifier; import java.util.Arrays; import java.util.List; import java.util.UUID; @@ -136,6 +140,25 @@ void testPagesRelatedMethodShouldThrowException(String method) { assertEquals(new Refl<>(DataGUI.class).getFieldObject("ERROR_MESSAGE"), throwable.getMessage()); } + private static Constructor[] privateConstructors() { + return Arrays.stream(DataGUI.class.getDeclaredConstructors()) + .filter(c -> Modifier.isPrivate(c.getModifiers())) + .toArray(Constructor[]::new); + } + + @ParameterizedTest + @MethodSource("privateConstructors") + void testPrivateConstructorsConverter(Constructor constructor) throws InvocationTargetException, InstantiationException, IllegalAccessException { + Object[] parameters = Arrays.stream(constructor.getParameterTypes()) + .map(TestUtils::mockParameter) + .map(o -> o instanceof Number ? 9 : o) + .toArray(Object[]::new); + Object object = ReflectionUtils.setAccessibleOrThrow(constructor).newInstance(parameters); + assertThrowsExactly(NotImplemented.class, () -> new Refl<>(object) + .getFieldRefl("dataConverter") + .invokeMethod("apply", (Object) null)); + } + @Test void testOpenPage() { int[][] slots = new int[][]{ From b9fd11844c4c4da87a1f9159bf1a7d43682fe61d Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 14:26:28 +0200 Subject: [PATCH 190/204] Refactored code --- build.gradle | 6 +++--- .../resources/commands/CreateRecipe.groovy | 6 +++--- .../main/resources/commands/PlayEffect.groovy | 2 +- .../resources/commands/PlayParticle.groovy | 2 +- .../it/angrybear/yagl/guis/PageableGUI.java | 20 ------------------ .../it/angrybear/yagl/guis/ResizableGUI.java | 21 ------------------- .../it/angrybear/yagl/parsers/GUIParser.java | 1 - 7 files changed, 8 insertions(+), 50 deletions(-) diff --git a/build.gradle b/build.gradle index 4d3d4c76..b48d4171 100644 --- a/build.gradle +++ b/build.gradle @@ -115,14 +115,14 @@ allprojects { testCompileOnly libs.lombok testAnnotationProcessor libs.lombok - if (!project.name.equals(TEST_MODULE)) testImplementation project(":${TEST_MODULE}") + if (project.name != TEST_MODULE) testImplementation project(":${TEST_MODULE}") - if (project.name.equals(DEMO_MODULE)) + if (project.name == DEMO_MODULE) rootProject.subprojects.findAll { it.name != TEST_MODULE && it.name != DEMO_MODULE } .each { implementation project(it.path) } } - if (project.name.equals(TEST_MODULE)) return + if (project.name == TEST_MODULE) return test { def projectName = project.name diff --git a/demo/src/main/resources/commands/CreateRecipe.groovy b/demo/src/main/resources/commands/CreateRecipe.groovy index 274656b6..eacd1e47 100644 --- a/demo/src/main/resources/commands/CreateRecipe.groovy +++ b/demo/src/main/resources/commands/CreateRecipe.groovy @@ -5,7 +5,7 @@ import it.angrybear.yagl.items.recipes.ShapedRecipe import it.angrybear.yagl.items.recipes.ShapelessRecipe import org.bukkit.entity.Player -def shaped(sender, label, args, output, name) { +static def shaped(sender, label, args, output, name) { try { def rows = Integer.valueOf(args[0]) def columns = Integer.valueOf(args[1]) @@ -22,7 +22,7 @@ def shaped(sender, label, args, output, name) { } } -def shapeless(sender, label, args, output, name) { +static def shapeless(sender, label, args, output, name) { try { if (args.length == 0) throw new IndexOutOfBoundsException() BukkitItem.newRecipeItem(output) @@ -39,7 +39,7 @@ def shapeless(sender, label, args, output, name) { } } -def furnace(sender, label, args, output, name) { +static def furnace(sender, label, args, output, name) { try { BukkitItem.newRecipeItem(output) .addRecipes(new FurnaceRecipe(name) diff --git a/demo/src/main/resources/commands/PlayEffect.groovy b/demo/src/main/resources/commands/PlayEffect.groovy index 2b75c516..b05911d8 100644 --- a/demo/src/main/resources/commands/PlayEffect.groovy +++ b/demo/src/main/resources/commands/PlayEffect.groovy @@ -11,7 +11,7 @@ import it.angrybear.yagl.wrappers.Potion import it.fulminazzo.fulmicollection.objects.Refl import org.bukkit.entity.Player -def getOption(sender, particleType, optionType, args) { +static def getOption(sender, particleType, optionType, args) { if (optionType == PotionParticleOption) new PotionParticleOption(new Potion(args[0], Integer.valueOf(args[1]), Boolean.valueOf(args[2]), Boolean.valueOf(args[3]))) diff --git a/demo/src/main/resources/commands/PlayParticle.groovy b/demo/src/main/resources/commands/PlayParticle.groovy index e4d1ec6b..7c8dbb84 100644 --- a/demo/src/main/resources/commands/PlayParticle.groovy +++ b/demo/src/main/resources/commands/PlayParticle.groovy @@ -13,7 +13,7 @@ import org.bukkit.Location import org.bukkit.entity.Player import org.bukkit.inventory.EquipmentSlot -def getOption(sender, particleType, optionType, args) { +static def getOption(sender, particleType, optionType, args) { if (optionType == DustParticleOption) new DustParticleOption(Color.fromARGB(args[0]), Float.valueOf(args[1])) if (optionType == DustTransitionParticleOption) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java index 6bc008d2..a6b697fb 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/PageableGUI.java @@ -477,11 +477,6 @@ public int columns() { return (PageableGUI) GUI.super.unsetTopSide(); } - @Override - public @NotNull Set topSlots() { - return GUI.super.topSlots(); - } - @Override public @NotNull PageableGUI setLeftSide(Item @NotNull ... contents) { return (PageableGUI) GUI.super.setLeftSide(contents); @@ -507,11 +502,6 @@ public int columns() { return (PageableGUI) GUI.super.unsetLeftSide(); } - @Override - public @NotNull Set leftSlots() { - return GUI.super.leftSlots(); - } - @Override public @NotNull PageableGUI setBottomSide(Item @NotNull ... contents) { return (PageableGUI) GUI.super.setBottomSide(contents); @@ -537,11 +527,6 @@ public int columns() { return (PageableGUI) GUI.super.unsetBottomSide(); } - @Override - public @NotNull Set bottomSlots() { - return GUI.super.bottomSlots(); - } - @Override public @NotNull PageableGUI setRightSide(Item @NotNull ... contents) { return (PageableGUI) GUI.super.setRightSide(contents); @@ -567,11 +552,6 @@ public int columns() { return (PageableGUI) GUI.super.unsetRightSide(); } - @Override - public @NotNull Set rightSlots() { - return GUI.super.rightSlots(); - } - @Override public @NotNull PageableGUI setNorthWest(Item @NotNull ... contents) { return (PageableGUI) GUI.super.setNorthWest(contents); diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/ResizableGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/ResizableGUI.java index 30736538..1b92006b 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/ResizableGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/ResizableGUI.java @@ -13,7 +13,6 @@ import org.jetbrains.annotations.Nullable; import java.util.Collection; -import java.util.Set; /** * Represents a "chest" GUI that can be resized. @@ -188,11 +187,6 @@ public void resize(int size) { return (ResizableGUI) super.unsetTopSide(); } - @Override - public @NotNull Set topSlots() { - return super.topSlots(); - } - @Override public @NotNull ResizableGUI setLeftSide(Item @NotNull ... contents) { return (ResizableGUI) super.setLeftSide(contents); @@ -218,11 +212,6 @@ public void resize(int size) { return (ResizableGUI) super.unsetLeftSide(); } - @Override - public @NotNull Set leftSlots() { - return super.leftSlots(); - } - @Override public @NotNull ResizableGUI setBottomSide(Item @NotNull ... contents) { return (ResizableGUI) super.setBottomSide(contents); @@ -248,11 +237,6 @@ public void resize(int size) { return (ResizableGUI) super.unsetBottomSide(); } - @Override - public @NotNull Set bottomSlots() { - return super.bottomSlots(); - } - @Override public @NotNull ResizableGUI setRightSide(Item @NotNull ... contents) { return (ResizableGUI) super.setRightSide(contents); @@ -278,11 +262,6 @@ public void resize(int size) { return (ResizableGUI) super.unsetRightSide(); } - @Override - public @NotNull Set rightSlots() { - return super.rightSlots(); - } - @Override public @NotNull ResizableGUI setNorthWest(Item @NotNull ... contents) { return (ResizableGUI) super.setNorthWest(contents); diff --git a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/GUIParser.java b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/GUIParser.java index fec8c882..0a055daf 100644 --- a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/GUIParser.java +++ b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/GUIParser.java @@ -47,7 +47,6 @@ protected BiFunctionException getLoader() { }; } - @SuppressWarnings("unchecked") @Override protected TriConsumer getDumper() { return (c, s, g) -> { From b013efdc2e27b2b7f54dea6072d80c2fc64400a8 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 14:28:15 +0200 Subject: [PATCH 191/204] Fixed grammar --- .../main/java/it/angrybear/yagl/parsers/TypedParser.java | 2 +- .../angrybear/yagl/parsers/SerializableFunctionParser.java | 6 +++--- .../main/java/it/angrybear/yagl/items/PersistentItem.java | 2 +- .../it/angrybear/yagl/listeners/PersistentListener.java | 2 +- .../src/main/java/it/angrybear/yagl/WrappersAdapter.java | 2 +- 5 files changed, 7 insertions(+), 7 deletions(-) diff --git a/common/serializer/src/main/java/it/angrybear/yagl/parsers/TypedParser.java b/common/serializer/src/main/java/it/angrybear/yagl/parsers/TypedParser.java index e09033ec..e1bffe1e 100644 --- a/common/serializer/src/main/java/it/angrybear/yagl/parsers/TypedParser.java +++ b/common/serializer/src/main/java/it/angrybear/yagl/parsers/TypedParser.java @@ -11,7 +11,7 @@ /** * This parser allows parsing an object using the {@link CallableYAMLParser} methods. - * However, it forces the saved object to store a type field, that contains the name of the class of the original object. + * However, it forces the saved object to store a type field, that contains the class name of the original object. * Upon loading, this class is retrieved (and will throw errors for invalid values) to recreate the object. * * @param the type parameter diff --git a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/SerializableFunctionParser.java b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/SerializableFunctionParser.java index 3e25f37e..78ec3172 100644 --- a/gui/serializer/src/main/java/it/angrybear/yagl/parsers/SerializableFunctionParser.java +++ b/gui/serializer/src/main/java/it/angrybear/yagl/parsers/SerializableFunctionParser.java @@ -34,7 +34,7 @@ protected BiFunctionException getLoader() { return (c, s) -> { ConfigurationSection section = c.getConfigurationSection(s); if (section == null) return null; - // Get type + // Get the type String type = section.getString("type"); if (type == null) throw new IllegalArgumentException("'type' cannot be null"); Class clazz = typeToClass(getOClass(), type); @@ -61,9 +61,9 @@ protected TriConsumer getDumper() { } /** - * Type to class class. + * Converts the given type to the corresponding class. * - * @param the type parameter + * @param the type of the class * @param mainClass the main class * @param type the type * @return the class diff --git a/item/bukkit/src/main/java/it/angrybear/yagl/items/PersistentItem.java b/item/bukkit/src/main/java/it/angrybear/yagl/items/PersistentItem.java index 92edf8b4..43037e05 100644 --- a/item/bukkit/src/main/java/it/angrybear/yagl/items/PersistentItem.java +++ b/item/bukkit/src/main/java/it/angrybear/yagl/items/PersistentItem.java @@ -100,7 +100,7 @@ public void interact(final @NotNull Player player, final @NotNull ItemStack item /** * Set the action executed on interacting. - * A player interacts with an item when they right-click with it in game. + * A player interacts with an item when they right-click with it in the game. * * @param action the action * @return this persistent item diff --git a/item/bukkit/src/main/java/it/angrybear/yagl/listeners/PersistentListener.java b/item/bukkit/src/main/java/it/angrybear/yagl/listeners/PersistentListener.java index 046265e1..a58d1589 100644 --- a/item/bukkit/src/main/java/it/angrybear/yagl/listeners/PersistentListener.java +++ b/item/bukkit/src/main/java/it/angrybear/yagl/listeners/PersistentListener.java @@ -80,7 +80,7 @@ protected void on(@NotNull PlayerDeathEvent event) { for (int i = 0; i < contents.length; i++) { int finalI = i; final ItemStack item = contents[i]; - // Save every PersistentItem with the MAINTAIN action, remove if they have DISAPPEAR. + // Save every PersistentItem with the MAINTAIN action, remove if they have the DISAPPEAR one. findPersistentItem(p -> { DeathAction deathAction = p.getDeathAction(); if (deathAction == null) return; diff --git a/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java b/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java index a7ceee1b..fad9c42b 100644 --- a/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java +++ b/wrappers/bukkit/src/main/java/it/angrybear/yagl/WrappersAdapter.java @@ -393,7 +393,7 @@ else if (dataType.getCanonicalName().equals("org.bukkit.block.data.BlockData")) String nbt = blockDataOption.getNBT().trim(); return nbt.isEmpty() ? material.createBlockData() : material.createBlockData(String.format("[%s]", nbt)); } else { - // Try creation from data type + // Try creation from the data type final Object finalOption; Constructor constructor = dataType.getDeclaredConstructors()[0]; int size = constructor.getParameterCount(); From 8a41ddcc31e6db73b1e143d5467a2422476bbbec Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 14:31:13 +0200 Subject: [PATCH 192/204] Fixed setPages not annotated as deprecated --- gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java | 1 + 1 file changed, 1 insertion(+) diff --git a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java index 2ffe0970..80babc32 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java +++ b/gui/base/src/main/java/it/angrybear/yagl/guis/DataGUI.java @@ -254,6 +254,7 @@ public int pages() { * @return this gui */ @Override + @Deprecated public @NotNull DataGUI setPages(int pages) { throw new IllegalStateException(ERROR_MESSAGE); } From f499db55a5ff7ccaeb4cf53599ab0ea87a2c4d03 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 14:37:36 +0200 Subject: [PATCH 193/204] Removed unnecessary GString --- .../main/groovy/it/angrybear/yagl/YAGL.groovy | 4 ++-- .../yagl/commands/ShellCommand.groovy | 2 +- .../main/resources/commands/GiveItem.groovy | 6 ++--- .../commands/GivePersistentItem.groovy | 6 ++--- .../resources/commands/OpenDataGUI.groovy | 10 ++++---- .../main/resources/commands/OpenGUI.groovy | 24 +++++++++---------- .../resources/commands/OpenPageableGUI.groovy | 10 ++++---- 7 files changed, 31 insertions(+), 31 deletions(-) diff --git a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 0c8912db..ad293c1a 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -38,7 +38,7 @@ class YAGL extends JavaPlugin { if (!commandsDir.exists()) saveDefaultCommands(commandsDir) File[] files = commandsDir.listFiles() if (files != null) - this.commands.addAll(files.findAll({ it.name.endsWith(".groovy") }).collect { new ShellCommand(it) }) + this.commands.addAll(files.findAll({ it.name.endsWith('.groovy') }).collect { new ShellCommand(it) }) commandMap().ifPresent { map -> this.commands.each { map.register(getName(), it) } } } @@ -76,7 +76,7 @@ class YAGL extends JavaPlugin { String fileName while ((fileName = reader.readLine()) != null) writeResourceToFile(commandsDir, fileName, resourceDir) } - Iterator jarEntries = JarUtils.getEntries(YAGL, "") + Iterator jarEntries = JarUtils.getEntries(YAGL, '') while (jarEntries.hasNext()) { def entry = jarEntries.next() if (entry.startsWith(resourceDir.substring(1)) && entry.length() > resourceDir.length()) diff --git a/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy index d89db548..932edd43 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy @@ -39,7 +39,7 @@ class ShellCommand extends Command { @Override boolean execute(@NotNull CommandSender sender, @NotNull String label, @NotNull String[] args) { - Binding binding = new Binding(["sender": sender, "label": label, "args": args]) + Binding binding = new Binding(['sender': sender, 'label': label, 'args': args]) new GroovyShell(binding).evaluate(this.shellCode) return true } diff --git a/demo/src/main/resources/commands/GiveItem.groovy b/demo/src/main/resources/commands/GiveItem.groovy index 4314a396..0314318f 100644 --- a/demo/src/main/resources/commands/GiveItem.groovy +++ b/demo/src/main/resources/commands/GiveItem.groovy @@ -13,11 +13,11 @@ def run = { sender, label, args -> item.setAmount(Integer.valueOf(args[1])) .setDurability(Integer.valueOf(args[2])) .setDisplayName(args[3]) - .setLore(args[4].split(";")) - .addEnchantments(Arrays.stream(args[5].split(";")) + .setLore(args[4].split(';')) + .addEnchantments(Arrays.stream(args[5].split(';')) .map(a -> WrapperParser.parseWrapperFromString(a, Enchantment)) .toArray(Enchantment[]::new)) - .addItemFlags(Arrays.stream(args[6].split(";")) + .addItemFlags(Arrays.stream(args[6].split(';')) .map(a -> ItemFlag.valueOf(a.toUpperCase())) .toArray(ItemFlag[]::new)) .setUnbreakable(Boolean.valueOf(args[7])) diff --git a/demo/src/main/resources/commands/GivePersistentItem.groovy b/demo/src/main/resources/commands/GivePersistentItem.groovy index aa3359f6..38a2dca7 100644 --- a/demo/src/main/resources/commands/GivePersistentItem.groovy +++ b/demo/src/main/resources/commands/GivePersistentItem.groovy @@ -18,11 +18,11 @@ def run = { sender, label, args -> item.setAmount(Integer.valueOf(args[3])) .setDurability(Integer.valueOf(args[4])) .setDisplayName(args[5]) - .setLore(args[6].split(";")) - .addEnchantments(Arrays.stream(args[7].split(";")) + .setLore(args[6].split(';')) + .addEnchantments(Arrays.stream(args[7].split(';')) .map(a -> WrapperParser.parseWrapperFromString(a, Enchantment)) .toArray(Enchantment[]::new)) - .addItemFlags(Arrays.stream(args[8].split(";")) + .addItemFlags(Arrays.stream(args[8].split(';')) .map(a -> ItemFlag.valueOf(a.toUpperCase())) .toArray(ItemFlag[]::new)) .setUnbreakable(Boolean.valueOf(args[9])) diff --git a/demo/src/main/resources/commands/OpenDataGUI.groovy b/demo/src/main/resources/commands/OpenDataGUI.groovy index b451c72f..cfdfedef 100644 --- a/demo/src/main/resources/commands/OpenDataGUI.groovy +++ b/demo/src/main/resources/commands/OpenDataGUI.groovy @@ -52,21 +52,21 @@ def run = { sender, label, args -> } catch (IllegalArgumentException ignored) { gui = DataGUI.newGUI(Integer.valueOf(args[0]), converter, data) } catch (IndexOutOfBoundsException ignored) { - sender.sendMessage("Usage: /opendatagui ") + sender.sendMessage('Usage: /opendatagui ') return } def size = gui.size() def middle = (int) Math.min(size / 2, 9 / 2) if (size > 1) { size -= 1 - gui.setContents(size - middle, BukkitItem.newItem(Material.OBSIDIAN).setDisplayName("&7Page: &e")) + gui.setContents(size - middle, BukkitItem.newItem(Material.OBSIDIAN).setDisplayName('&7Page: &e')) .setPreviousPage(size - middle * 2, BukkitItem.newItem(Material.REDSTONE_BLOCK) - .setDisplayName("&7Go to page &e")) + .setDisplayName('&7Go to page &e')) .setNextPage(size, BukkitItem.newItem(Material.EMERALD_BLOCK) - .setDisplayName("&7Go to page &e")) + .setDisplayName('&7Go to page &e')) } - gui.setTitle("Page #") + gui.setTitle('Page #') .onClickOutside((v, g) -> v.sendMessage('Please only click inside me!')) .onOpenGUI((v, g) -> v.sendMessage(g.apply('Opening page '))) .onCloseGUI((v, g) -> v.sendMessage('Goodbye!')) diff --git a/demo/src/main/resources/commands/OpenGUI.groovy b/demo/src/main/resources/commands/OpenGUI.groovy index b3979163..48bfa08a 100644 --- a/demo/src/main/resources/commands/OpenGUI.groovy +++ b/demo/src/main/resources/commands/OpenGUI.groovy @@ -11,14 +11,14 @@ def run = { sender, label, args -> if (sender instanceof Player) try { def columns = 9 - def border = Item.newItem("black_stained_glass_pane").setDisplayName(" ") + def border = Item.newItem('black_stained_glass_pane').setDisplayName(' ') GUI gui try { gui = GUI.newGUI(EnumUtils.valueOf(GUIType, args[0])) } catch (IllegalArgumentException ignored) { gui = GUI.newResizableGUI(Integer.valueOf(args[0])) } catch (IndexOutOfBoundsException ignored) { - sender.sendMessage("Usage: /opengui ") + sender.sendMessage('Usage: /opengui ') return } for (int i = 0; i < Math.min(gui.size(), columns); i += 1) { @@ -30,24 +30,24 @@ def run = { sender, label, args -> gui.setContents(gui.size() - i - 1, border) } def middle = (int) (gui.size() / 2) - gui.setContents(middle, Item.newItem("gold_block").setDisplayName("This is a GUI!") - .addEnchantment("unbreaking", 1) + gui.setContents(middle, Item.newItem('gold_block').setDisplayName('This is a GUI!') + .addEnchantment('unbreaking', 1) .addItemFlags(ItemFlag.HIDE_ENCHANTS)) if (middle - 1 >= 0) - gui.setContents(middle - 1, Item.newItem("diamond_sword") - .setDisplayName("Pick me!") - .addEnchantment("sharpness", 2)) + gui.setContents(middle - 1, Item.newItem('diamond_sword') + .setDisplayName('Pick me!') + .addEnchantment('sharpness', 2)) .setMovable(middle - 1, true) if (middle + 1 < gui.size()) - gui.setContents(middle + 1, ItemGUIContent.newInstance("diamond_pickaxe") - .setDisplayName("Can't pick me...") - .addEnchantment("efficiency", 10) + gui.setContents(middle + 1, ItemGUIContent.newInstance('diamond_pickaxe') + .setDisplayName('Can\'t pick me...') + .addEnchantment('efficiency', 10) .onClickItem((v, g, c) -> v.sendMessage('You cannot pick this item!'))) - gui.setTitle(" GUI") + gui.setTitle(' GUI') .onClickOutside((v, g) -> v.sendMessage('Please only click inside me!')) .onOpenGUI((v, g) -> v.sendMessage('Opening the GUI... voila')) .onCloseGUI((v, g) -> v.sendMessage('Goodbye!')) - .setVariable("name", "Demo") + .setVariable('name', 'Demo') .open(GUIManager.getViewer(sender)) } catch (NumberFormatException ignored) { diff --git a/demo/src/main/resources/commands/OpenPageableGUI.groovy b/demo/src/main/resources/commands/OpenPageableGUI.groovy index 1c16fcb3..5e927141 100644 --- a/demo/src/main/resources/commands/OpenPageableGUI.groovy +++ b/demo/src/main/resources/commands/OpenPageableGUI.groovy @@ -15,21 +15,21 @@ def run = { sender, label, args -> } catch (IllegalArgumentException ignored) { gui = PageableGUI.newGUI(Integer.valueOf(args[0])).setPages(Integer.valueOf(args[1])) } catch (IndexOutOfBoundsException ignored) { - sender.sendMessage("Usage: /openpageablegui ") + sender.sendMessage('Usage: /openpageablegui ') return } def size = gui.size() def middle = (int) Math.min(size / 2, 9 / 2) if (size > 1) { size -= 1 - gui.setContents(size - middle, BukkitItem.newItem(Material.OBSIDIAN).setDisplayName("&7Page: &e")) + gui.setContents(size - middle, BukkitItem.newItem(Material.OBSIDIAN).setDisplayName('&7Page: &e')) .setPreviousPage(size - middle * 2, BukkitItem.newItem(Material.REDSTONE_BLOCK) - .setDisplayName("&7Go to page &e")) + .setDisplayName('&7Go to page &e')) .setNextPage(size, BukkitItem.newItem(Material.EMERALD_BLOCK) - .setDisplayName("&7Go to page &e")) + .setDisplayName('&7Go to page &e')) } - gui.setTitle("Page #") + gui.setTitle('Page #') .onClickOutside((v, g) -> v.sendMessage('Please only click inside me!')) .onOpenGUI((v, g) -> v.sendMessage(g.apply('Opening page '))) .onCloseGUI((v, g) -> v.sendMessage('Goodbye!')) From bf05b12ef851d4b318c7d5010e1b5e4d70569a44 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 14:58:33 +0200 Subject: [PATCH 194/204] Replaced unnecessary getter methods --- demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 14 +++++++------- .../it/angrybear/yagl/commands/ShellCommand.groovy | 4 ++-- .../resources/commands/ApplyPotionEffect.groovy | 2 +- .../main/resources/commands/CreateRecipe.groovy | 2 +- .../main/resources/commands/GetEnchantment.groovy | 6 +++--- demo/src/main/resources/commands/GiveItem.groovy | 2 +- .../resources/commands/GivePersistentItem.groovy | 2 +- .../src/main/resources/commands/OpenDataGUI.groovy | 2 +- demo/src/main/resources/commands/OpenGUI.groovy | 2 +- .../main/resources/commands/OpenPageableGUI.groovy | 2 +- demo/src/main/resources/commands/PlayEffect.groovy | 4 ++-- .../main/resources/commands/PlayParticle.groovy | 4 ++-- .../resources/commands/PlayYAGLCustomSound.groovy | 2 +- .../main/resources/commands/PlayYAGLSound.groovy | 2 +- 14 files changed, 25 insertions(+), 25 deletions(-) diff --git a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy index ad293c1a..d87667e0 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -19,8 +19,8 @@ class YAGL extends JavaPlugin { @Override void onEnable() { loadCommands() - Bukkit.getPluginManager().registerEvents(new PersistentListener(), this) - getLogger().info("Loaded ${commands.size()} commands") + Bukkit.pluginManager.registerEvents(new PersistentListener(), this) + logger.info("Loaded ${commands.size()} commands") } @Override @@ -29,18 +29,18 @@ class YAGL extends JavaPlugin { } /** - * Loads all the commands from the {@link #getDataFolder()}/commands directory. + * Loads all the commands from the {@link #dataFolder}/commands directory. * If it does not exist, it is created using {@link #saveDefaultCommands(File)}. */ void loadCommands() { this.commands.clear() - File commandsDir = new File(getDataFolder(), 'commands') + File commandsDir = new File(dataFolder, 'commands') if (!commandsDir.exists()) saveDefaultCommands(commandsDir) File[] files = commandsDir.listFiles() if (files != null) this.commands.addAll(files.findAll({ it.name.endsWith('.groovy') }).collect { new ShellCommand(it) }) - commandMap().ifPresent { map -> this.commands.each { map.register(getName(), it) } } + commandMap().ifPresent { map -> this.commands.each { map.register(name, it) } } } /** @@ -49,7 +49,7 @@ class YAGL extends JavaPlugin { void unloadCommands() { commandMap().ifPresent(map -> { Map commands = new Refl<>(map).getFieldObject('knownCommands') - if (commands == null) getLogger().warning('Could not find \'knownCommands\' field in CommandMap') + if (commands == null) logger.warning('Could not find \'knownCommands\' field in CommandMap') else commands.keySet().collect().each { key -> Command value = commands.get(key) if (this.commands.contains(value)) commands.remove(key, value) @@ -58,7 +58,7 @@ class YAGL extends JavaPlugin { } private static Optional commandMap() { - def pluginManager = Bukkit.getPluginManager() + def pluginManager = Bukkit.pluginManager // Terrible line, but necessary for JaCoCo coverage report to 100% pluginManager == null ? Optional.empty() : Optional.ofNullable((CommandMap) new Refl<>(pluginManager) .getFieldObject('commandMap')) diff --git a/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy index 932edd43..63d8e410 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy @@ -14,7 +14,7 @@ import java.util.regex.Pattern @CompileStatic class ShellCommand extends Command { private static final String NUMBER_FORMAT_REGEX = '(catch *\\(NumberFormatException +ignored\\) *\\{\\n)[ \\t]*(\\n *})' - private static final String INVALID_NUMBER_CODE = 'sender.sendMessage(e.getMessage().replace(\'For input string: \', \'Invalid number \'))' + private static final String INVALID_NUMBER_CODE = 'sender.sendMessage(e.message.replace(\'For input string: \', \'Invalid number \'))' private final String shellCode /** @@ -23,7 +23,7 @@ class ShellCommand extends Command { * @param file the file containing the script */ ShellCommand(final @NotNull File file) { - super(file.getName().substring(0, file.getName().lastIndexOf('.'))) + super(file.name.substring(0, file.name.lastIndexOf('.'))) def code = FileUtils.readFileToString(file) if (code == null) { this.shellCode = '' diff --git a/demo/src/main/resources/commands/ApplyPotionEffect.groovy b/demo/src/main/resources/commands/ApplyPotionEffect.groovy index b0f20a0f..9355d6f9 100644 --- a/demo/src/main/resources/commands/ApplyPotionEffect.groovy +++ b/demo/src/main/resources/commands/ApplyPotionEffect.groovy @@ -14,7 +14,7 @@ def run = { sender, label, args -> } catch (NumberFormatException ignored) { } catch (Exception e) { - sender.sendMessage(e.getMessage()) + sender.sendMessage(e.message) } } else sender.sendMessage('Console cannot execute this command!') } \ No newline at end of file diff --git a/demo/src/main/resources/commands/CreateRecipe.groovy b/demo/src/main/resources/commands/CreateRecipe.groovy index eacd1e47..629c9883 100644 --- a/demo/src/main/resources/commands/CreateRecipe.groovy +++ b/demo/src/main/resources/commands/CreateRecipe.groovy @@ -64,7 +64,7 @@ def run = { sender, label, args -> } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /createrecipe ') } catch (Exception e) { - sender.sendMessage(e.getMessage()) + sender.sendMessage(e.message) } else sender.sendMessage('Console cannot execute this command!') } \ No newline at end of file diff --git a/demo/src/main/resources/commands/GetEnchantment.groovy b/demo/src/main/resources/commands/GetEnchantment.groovy index e687593e..3bcf3736 100644 --- a/demo/src/main/resources/commands/GetEnchantment.groovy +++ b/demo/src/main/resources/commands/GetEnchantment.groovy @@ -11,11 +11,11 @@ def run = { sender, label, args -> try { Enchantment enchantment = new Enchantment(args[0], Integer.valueOf(args[1])) ItemStack book = new ItemStack(Material.ENCHANTED_BOOK) - EnchantmentStorageMeta meta = book.getItemMeta() + EnchantmentStorageMeta meta = book.itemMeta Tuple tuple = WrappersAdapter.wEnchantToEnchant(enchantment) - meta.addStoredEnchant(tuple.getKey(), tuple.getValue(), true) + meta.addStoredEnchant(tuple.key, tuple.value, true) book.setItemMeta(meta) - sender.getInventory().addItem(book) + sender.inventory.addItem(book) } catch (NumberFormatException ignored) { } catch (IndexOutOfBoundsException ignored) { diff --git a/demo/src/main/resources/commands/GiveItem.groovy b/demo/src/main/resources/commands/GiveItem.groovy index 0314318f..beac43ee 100644 --- a/demo/src/main/resources/commands/GiveItem.groovy +++ b/demo/src/main/resources/commands/GiveItem.groovy @@ -25,7 +25,7 @@ def run = { sender, label, args -> } catch (IndexOutOfBoundsException ignored) { } - sender.getInventory().addItem(item.copy(BukkitItem).create()) + sender.inventory.addItem(item.copy(BukkitItem).create()) } catch (NumberFormatException ignored) { } catch (IndexOutOfBoundsException ignored) { diff --git a/demo/src/main/resources/commands/GivePersistentItem.groovy b/demo/src/main/resources/commands/GivePersistentItem.groovy index 38a2dca7..b515683f 100644 --- a/demo/src/main/resources/commands/GivePersistentItem.groovy +++ b/demo/src/main/resources/commands/GivePersistentItem.groovy @@ -30,7 +30,7 @@ def run = { sender, label, args -> } catch (IndexOutOfBoundsException ignored) { } - sender.getInventory().addItem(item.copy(BukkitItem).create()) + sender.inventory.addItem(item.copy(BukkitItem).create()) } catch (NumberFormatException ignored) { } catch (IndexOutOfBoundsException ignored) { diff --git a/demo/src/main/resources/commands/OpenDataGUI.groovy b/demo/src/main/resources/commands/OpenDataGUI.groovy index cfdfedef..151e5bf4 100644 --- a/demo/src/main/resources/commands/OpenDataGUI.groovy +++ b/demo/src/main/resources/commands/OpenDataGUI.groovy @@ -74,7 +74,7 @@ def run = { sender, label, args -> } catch (NumberFormatException ignored) { } catch (Exception e) { - sender.sendMessage(e.getMessage()) + sender.sendMessage(e.message) } else sender.sendMessage('Console cannot execute this command!') } \ No newline at end of file diff --git a/demo/src/main/resources/commands/OpenGUI.groovy b/demo/src/main/resources/commands/OpenGUI.groovy index 48bfa08a..0203a420 100644 --- a/demo/src/main/resources/commands/OpenGUI.groovy +++ b/demo/src/main/resources/commands/OpenGUI.groovy @@ -52,7 +52,7 @@ def run = { sender, label, args -> } catch (NumberFormatException ignored) { } catch (Exception e) { - sender.sendMessage(e.getMessage()) + sender.sendMessage(e.message) } else sender.sendMessage('Console cannot execute this command!') } \ No newline at end of file diff --git a/demo/src/main/resources/commands/OpenPageableGUI.groovy b/demo/src/main/resources/commands/OpenPageableGUI.groovy index 5e927141..f9e9e570 100644 --- a/demo/src/main/resources/commands/OpenPageableGUI.groovy +++ b/demo/src/main/resources/commands/OpenPageableGUI.groovy @@ -37,7 +37,7 @@ def run = { sender, label, args -> } catch (NumberFormatException ignored) { } catch (Exception e) { - sender.sendMessage(e.getMessage()) + sender.sendMessage(e.message) } else sender.sendMessage('Console cannot execute this command!') } \ No newline at end of file diff --git a/demo/src/main/resources/commands/PlayEffect.groovy b/demo/src/main/resources/commands/PlayEffect.groovy index b05911d8..8e3962a4 100644 --- a/demo/src/main/resources/commands/PlayEffect.groovy +++ b/demo/src/main/resources/commands/PlayEffect.groovy @@ -44,13 +44,13 @@ def run = { sender, label, args -> def option = getOption(sender, type, optionType, Arrays.copyOfRange(args, 1, args.length)) particle = type.create(option) } else particle = type.create() - WrappersAdapter.spawnEffect(sender, particle, sender.getEyeLocation()) + WrappersAdapter.spawnEffect(sender, particle, sender.eyeLocation) } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /playeffect ') } catch (NumberFormatException ignored) { } catch (Exception e) { - sender.sendMessage(e.getMessage()) + sender.sendMessage(e.message) } } else sender.sendMessage('Console cannot execute this command!') } \ No newline at end of file diff --git a/demo/src/main/resources/commands/PlayParticle.groovy b/demo/src/main/resources/commands/PlayParticle.groovy index 7c8dbb84..3df6de64 100644 --- a/demo/src/main/resources/commands/PlayParticle.groovy +++ b/demo/src/main/resources/commands/PlayParticle.groovy @@ -44,13 +44,13 @@ def run = { sender, label, args -> def option = getOption(sender, type, optionType, Arrays.copyOfRange(args, 1, args.length)) particle = type.create(option) } else particle = type.create() - WrappersAdapter.spawnParticle(sender, particle, sender.getEyeLocation(), 1) + WrappersAdapter.spawnParticle(sender, particle, sender.eyeLocation, 1) } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /playparticle ') } catch (NumberFormatException ignored) { } catch (Exception e) { - sender.sendMessage(e.getMessage()) + sender.sendMessage(e.message) } } else sender.sendMessage('Console cannot execute this command!') } \ No newline at end of file diff --git a/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy b/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy index fb4143c7..11f0a021 100644 --- a/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy +++ b/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy @@ -12,7 +12,7 @@ def run = { sender, label, args -> } catch (NumberFormatException ignored) { } catch (Exception e) { - sender.sendMessage(e.getMessage()) + sender.sendMessage(e.message) } } else sender.sendMessage('Console cannot execute this command!') } \ No newline at end of file diff --git a/demo/src/main/resources/commands/PlayYAGLSound.groovy b/demo/src/main/resources/commands/PlayYAGLSound.groovy index d7600a62..fa69d0f6 100644 --- a/demo/src/main/resources/commands/PlayYAGLSound.groovy +++ b/demo/src/main/resources/commands/PlayYAGLSound.groovy @@ -12,7 +12,7 @@ def run = { sender, label, args -> } catch (NumberFormatException ignored) { } catch (Exception e) { - sender.sendMessage(e.getMessage()) + sender.sendMessage(e.message) } } else sender.sendMessage('Console cannot execute this command!') } \ No newline at end of file From 65fe8821c78158a4aab9f43ebe8274c522d5ece1 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 14:59:56 +0200 Subject: [PATCH 195/204] Fixed file not starting with new line --- demo/src/main/resources/commands/ApplyPotionEffect.groovy | 2 +- demo/src/main/resources/commands/CreateRecipe.groovy | 2 +- demo/src/main/resources/commands/GetEnchantment.groovy | 2 +- demo/src/main/resources/commands/GiveItem.groovy | 2 +- demo/src/main/resources/commands/GivePersistentItem.groovy | 2 +- demo/src/main/resources/commands/OpenDataGUI.groovy | 2 +- demo/src/main/resources/commands/OpenGUI.groovy | 2 +- demo/src/main/resources/commands/OpenPageableGUI.groovy | 2 +- demo/src/main/resources/commands/PlayEffect.groovy | 2 +- demo/src/main/resources/commands/PlayParticle.groovy | 2 +- demo/src/main/resources/commands/PlayYAGLCustomSound.groovy | 2 +- demo/src/main/resources/commands/PlayYAGLSound.groovy | 2 +- 12 files changed, 12 insertions(+), 12 deletions(-) diff --git a/demo/src/main/resources/commands/ApplyPotionEffect.groovy b/demo/src/main/resources/commands/ApplyPotionEffect.groovy index 9355d6f9..d412a7b8 100644 --- a/demo/src/main/resources/commands/ApplyPotionEffect.groovy +++ b/demo/src/main/resources/commands/ApplyPotionEffect.groovy @@ -17,4 +17,4 @@ def run = { sender, label, args -> sender.sendMessage(e.message) } } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/CreateRecipe.groovy b/demo/src/main/resources/commands/CreateRecipe.groovy index 629c9883..a917b528 100644 --- a/demo/src/main/resources/commands/CreateRecipe.groovy +++ b/demo/src/main/resources/commands/CreateRecipe.groovy @@ -67,4 +67,4 @@ def run = { sender, label, args -> sender.sendMessage(e.message) } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/GetEnchantment.groovy b/demo/src/main/resources/commands/GetEnchantment.groovy index 3bcf3736..cf5315e5 100644 --- a/demo/src/main/resources/commands/GetEnchantment.groovy +++ b/demo/src/main/resources/commands/GetEnchantment.groovy @@ -22,4 +22,4 @@ def run = { sender, label, args -> sender.sendMessage('Usage: /getenchantment ') } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/GiveItem.groovy b/demo/src/main/resources/commands/GiveItem.groovy index beac43ee..8ed8cc3b 100644 --- a/demo/src/main/resources/commands/GiveItem.groovy +++ b/demo/src/main/resources/commands/GiveItem.groovy @@ -33,4 +33,4 @@ def run = { sender, label, args -> sender.sendMessage('At least material is required!') } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/GivePersistentItem.groovy b/demo/src/main/resources/commands/GivePersistentItem.groovy index b515683f..6a88b685 100644 --- a/demo/src/main/resources/commands/GivePersistentItem.groovy +++ b/demo/src/main/resources/commands/GivePersistentItem.groovy @@ -38,4 +38,4 @@ def run = { sender, label, args -> sender.sendMessage('At least death-action, mobility and material are required!') } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/OpenDataGUI.groovy b/demo/src/main/resources/commands/OpenDataGUI.groovy index 151e5bf4..c3dfff04 100644 --- a/demo/src/main/resources/commands/OpenDataGUI.groovy +++ b/demo/src/main/resources/commands/OpenDataGUI.groovy @@ -77,4 +77,4 @@ def run = { sender, label, args -> sender.sendMessage(e.message) } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/OpenGUI.groovy b/demo/src/main/resources/commands/OpenGUI.groovy index 0203a420..dd93d805 100644 --- a/demo/src/main/resources/commands/OpenGUI.groovy +++ b/demo/src/main/resources/commands/OpenGUI.groovy @@ -55,4 +55,4 @@ def run = { sender, label, args -> sender.sendMessage(e.message) } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/OpenPageableGUI.groovy b/demo/src/main/resources/commands/OpenPageableGUI.groovy index f9e9e570..9a0c5a09 100644 --- a/demo/src/main/resources/commands/OpenPageableGUI.groovy +++ b/demo/src/main/resources/commands/OpenPageableGUI.groovy @@ -40,4 +40,4 @@ def run = { sender, label, args -> sender.sendMessage(e.message) } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/PlayEffect.groovy b/demo/src/main/resources/commands/PlayEffect.groovy index 8e3962a4..4ff31da5 100644 --- a/demo/src/main/resources/commands/PlayEffect.groovy +++ b/demo/src/main/resources/commands/PlayEffect.groovy @@ -53,4 +53,4 @@ def run = { sender, label, args -> sender.sendMessage(e.message) } } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/PlayParticle.groovy b/demo/src/main/resources/commands/PlayParticle.groovy index 3df6de64..adc08404 100644 --- a/demo/src/main/resources/commands/PlayParticle.groovy +++ b/demo/src/main/resources/commands/PlayParticle.groovy @@ -53,4 +53,4 @@ def run = { sender, label, args -> sender.sendMessage(e.message) } } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy b/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy index 11f0a021..533d7fd1 100644 --- a/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy +++ b/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy @@ -15,4 +15,4 @@ def run = { sender, label, args -> sender.sendMessage(e.message) } } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} diff --git a/demo/src/main/resources/commands/PlayYAGLSound.groovy b/demo/src/main/resources/commands/PlayYAGLSound.groovy index fa69d0f6..11864b92 100644 --- a/demo/src/main/resources/commands/PlayYAGLSound.groovy +++ b/demo/src/main/resources/commands/PlayYAGLSound.groovy @@ -15,4 +15,4 @@ def run = { sender, label, args -> sender.sendMessage(e.message) } } else sender.sendMessage('Console cannot execute this command!') -} \ No newline at end of file +} From bc558eb6d2e5c6c4d8f072f86b9306fab4d7cf17 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 15:01:03 +0200 Subject: [PATCH 196/204] Updated tests --- .../test/java/it/angrybear/yagl/commands/ShellCommandTest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java b/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java index 719568c3..65ef6f29 100644 --- a/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java +++ b/demo/src/test/java/it/angrybear/yagl/commands/ShellCommandTest.java @@ -38,7 +38,7 @@ void testNumberFormatExceptionReplacement() { " try {\n" + " sender.sendMessage(\"Your number is ${Integer.valueOf(args[0])}\")\n" + " } catch (NumberFormatException ignored) {\n" + - " sender.sendMessage(e.getMessage().replace('For input string: ', 'Invalid number '))\n" + + " sender.sendMessage(e.message.replace('For input string: ', 'Invalid number '))\n" + " }\n" + "}\n" + "run(sender, label, args)"; From 951419c67a0e7b3439df07328b53faa2b4306112 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 15:02:17 +0200 Subject: [PATCH 197/204] Removed unnecessary imports --- demo/src/main/resources/commands/GivePersistentItem.groovy | 1 - 1 file changed, 1 deletion(-) diff --git a/demo/src/main/resources/commands/GivePersistentItem.groovy b/demo/src/main/resources/commands/GivePersistentItem.groovy index 6a88b685..7bf65c6b 100644 --- a/demo/src/main/resources/commands/GivePersistentItem.groovy +++ b/demo/src/main/resources/commands/GivePersistentItem.groovy @@ -1,6 +1,5 @@ import it.angrybear.yagl.items.BukkitItem import it.angrybear.yagl.items.DeathAction -import it.angrybear.yagl.items.Item import it.angrybear.yagl.items.Mobility import it.angrybear.yagl.items.PersistentItem import it.angrybear.yagl.items.fields.ItemFlag From fedafd2062f71eb3924bed91fb947c1f7baac7e9 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 15:12:48 +0200 Subject: [PATCH 198/204] Added comments for empty NumberFormatException blocks --- .../groovy/it/angrybear/yagl/commands/ShellCommand.groovy | 2 +- demo/src/main/resources/commands/ApplyPotionEffect.groovy | 2 +- demo/src/main/resources/commands/CreateRecipe.groovy | 8 ++++---- demo/src/main/resources/commands/GetEnchantment.groovy | 2 +- demo/src/main/resources/commands/GiveItem.groovy | 2 +- .../src/main/resources/commands/GivePersistentItem.groovy | 2 +- demo/src/main/resources/commands/OpenDataGUI.groovy | 2 +- demo/src/main/resources/commands/OpenGUI.groovy | 2 +- demo/src/main/resources/commands/OpenPageableGUI.groovy | 2 +- demo/src/main/resources/commands/PlayEffect.groovy | 2 +- demo/src/main/resources/commands/PlayParticle.groovy | 2 +- .../main/resources/commands/PlayYAGLCustomSound.groovy | 2 +- demo/src/main/resources/commands/PlayYAGLSound.groovy | 2 +- .../test/resources/number-format-exception-command.groovy | 2 +- 14 files changed, 17 insertions(+), 17 deletions(-) diff --git a/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy index 63d8e410..c09d2303 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy @@ -13,7 +13,7 @@ import java.util.regex.Pattern */ @CompileStatic class ShellCommand extends Command { - private static final String NUMBER_FORMAT_REGEX = '(catch *\\(NumberFormatException +ignored\\) *\\{\\n)[ \\t]*(\\n *})' + private static final String NUMBER_FORMAT_REGEX = '(catch *\\(NumberFormatException +ignored\\) *\\{\\n)[ \\t]*(?:// auto-generated code)?(\\n *})' private static final String INVALID_NUMBER_CODE = 'sender.sendMessage(e.message.replace(\'For input string: \', \'Invalid number \'))' private final String shellCode diff --git a/demo/src/main/resources/commands/ApplyPotionEffect.groovy b/demo/src/main/resources/commands/ApplyPotionEffect.groovy index d412a7b8..d2da01ab 100644 --- a/demo/src/main/resources/commands/ApplyPotionEffect.groovy +++ b/demo/src/main/resources/commands/ApplyPotionEffect.groovy @@ -12,7 +12,7 @@ def run = { sender, label, args -> } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /applypotioneffect ') } catch (NumberFormatException ignored) { - + // auto-generated code } catch (Exception e) { sender.sendMessage(e.message) } diff --git a/demo/src/main/resources/commands/CreateRecipe.groovy b/demo/src/main/resources/commands/CreateRecipe.groovy index a917b528..3efc3b77 100644 --- a/demo/src/main/resources/commands/CreateRecipe.groovy +++ b/demo/src/main/resources/commands/CreateRecipe.groovy @@ -16,7 +16,7 @@ static def shaped(sender, label, args, output, name) { BukkitItem.newRecipeItem(output).addRecipes(recipe).registerRecipes() sender.sendMessage('Ok') } catch (NumberFormatException ignored) { - + // auto-generated code } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /createrecipe shaped ') } @@ -33,7 +33,7 @@ static def shapeless(sender, label, args, output, name) { .registerRecipes() sender.sendMessage('Ok') } catch (NumberFormatException ignored) { - + // auto-generated code } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /createrecipe shapeless ') } @@ -49,7 +49,7 @@ static def furnace(sender, label, args, output, name) { .registerRecipes() sender.sendMessage('Ok') } catch (NumberFormatException ignored) { - + // auto-generated code } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /createrecipe furnace ') } @@ -60,7 +60,7 @@ def run = { sender, label, args -> try { "${args[2].toLowerCase()}"(sender, label, Arrays.copyOfRange(args, 3, args.length), args[1], args[0]) } catch (NumberFormatException ignored) { - + // auto-generated code } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /createrecipe ') } catch (Exception e) { diff --git a/demo/src/main/resources/commands/GetEnchantment.groovy b/demo/src/main/resources/commands/GetEnchantment.groovy index cf5315e5..40c20ae6 100644 --- a/demo/src/main/resources/commands/GetEnchantment.groovy +++ b/demo/src/main/resources/commands/GetEnchantment.groovy @@ -17,7 +17,7 @@ def run = { sender, label, args -> book.setItemMeta(meta) sender.inventory.addItem(book) } catch (NumberFormatException ignored) { - + // auto-generated code } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /getenchantment ') } diff --git a/demo/src/main/resources/commands/GiveItem.groovy b/demo/src/main/resources/commands/GiveItem.groovy index 8ed8cc3b..4d4396ed 100644 --- a/demo/src/main/resources/commands/GiveItem.groovy +++ b/demo/src/main/resources/commands/GiveItem.groovy @@ -27,7 +27,7 @@ def run = { sender, label, args -> } sender.inventory.addItem(item.copy(BukkitItem).create()) } catch (NumberFormatException ignored) { - + // auto-generated code } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /giveitem ') sender.sendMessage('At least material is required!') diff --git a/demo/src/main/resources/commands/GivePersistentItem.groovy b/demo/src/main/resources/commands/GivePersistentItem.groovy index 7bf65c6b..516e33b7 100644 --- a/demo/src/main/resources/commands/GivePersistentItem.groovy +++ b/demo/src/main/resources/commands/GivePersistentItem.groovy @@ -31,7 +31,7 @@ def run = { sender, label, args -> } sender.inventory.addItem(item.copy(BukkitItem).create()) } catch (NumberFormatException ignored) { - + // auto-generated code } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /givepersistentitem ') sender.sendMessage('At least death-action, mobility and material are required!') diff --git a/demo/src/main/resources/commands/OpenDataGUI.groovy b/demo/src/main/resources/commands/OpenDataGUI.groovy index c3dfff04..b9767488 100644 --- a/demo/src/main/resources/commands/OpenDataGUI.groovy +++ b/demo/src/main/resources/commands/OpenDataGUI.groovy @@ -72,7 +72,7 @@ def run = { sender, label, args -> .onCloseGUI((v, g) -> v.sendMessage('Goodbye!')) .open(GUIManager.getViewer(sender)) } catch (NumberFormatException ignored) { - + // auto-generated code } catch (Exception e) { sender.sendMessage(e.message) } diff --git a/demo/src/main/resources/commands/OpenGUI.groovy b/demo/src/main/resources/commands/OpenGUI.groovy index dd93d805..52845035 100644 --- a/demo/src/main/resources/commands/OpenGUI.groovy +++ b/demo/src/main/resources/commands/OpenGUI.groovy @@ -50,7 +50,7 @@ def run = { sender, label, args -> .setVariable('name', 'Demo') .open(GUIManager.getViewer(sender)) } catch (NumberFormatException ignored) { - + // auto-generated code } catch (Exception e) { sender.sendMessage(e.message) } diff --git a/demo/src/main/resources/commands/OpenPageableGUI.groovy b/demo/src/main/resources/commands/OpenPageableGUI.groovy index 9a0c5a09..656aec92 100644 --- a/demo/src/main/resources/commands/OpenPageableGUI.groovy +++ b/demo/src/main/resources/commands/OpenPageableGUI.groovy @@ -35,7 +35,7 @@ def run = { sender, label, args -> .onCloseGUI((v, g) -> v.sendMessage('Goodbye!')) .open(GUIManager.getViewer(sender)) } catch (NumberFormatException ignored) { - + // auto-generated code } catch (Exception e) { sender.sendMessage(e.message) } diff --git a/demo/src/main/resources/commands/PlayEffect.groovy b/demo/src/main/resources/commands/PlayEffect.groovy index 4ff31da5..86e8a963 100644 --- a/demo/src/main/resources/commands/PlayEffect.groovy +++ b/demo/src/main/resources/commands/PlayEffect.groovy @@ -48,7 +48,7 @@ def run = { sender, label, args -> } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /playeffect ') } catch (NumberFormatException ignored) { - + // auto-generated code } catch (Exception e) { sender.sendMessage(e.message) } diff --git a/demo/src/main/resources/commands/PlayParticle.groovy b/demo/src/main/resources/commands/PlayParticle.groovy index adc08404..cb0a6863 100644 --- a/demo/src/main/resources/commands/PlayParticle.groovy +++ b/demo/src/main/resources/commands/PlayParticle.groovy @@ -48,7 +48,7 @@ def run = { sender, label, args -> } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /playparticle ') } catch (NumberFormatException ignored) { - + // auto-generated code } catch (Exception e) { sender.sendMessage(e.message) } diff --git a/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy b/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy index 533d7fd1..2b81a2ee 100644 --- a/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy +++ b/demo/src/main/resources/commands/PlayYAGLCustomSound.groovy @@ -10,7 +10,7 @@ def run = { sender, label, args -> } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /playsound ') } catch (NumberFormatException ignored) { - + // auto-generated code } catch (Exception e) { sender.sendMessage(e.message) } diff --git a/demo/src/main/resources/commands/PlayYAGLSound.groovy b/demo/src/main/resources/commands/PlayYAGLSound.groovy index 11864b92..1c855482 100644 --- a/demo/src/main/resources/commands/PlayYAGLSound.groovy +++ b/demo/src/main/resources/commands/PlayYAGLSound.groovy @@ -10,7 +10,7 @@ def run = { sender, label, args -> } catch (IndexOutOfBoundsException ignored) { sender.sendMessage('Usage: /playsound ') } catch (NumberFormatException ignored) { - + // auto-generated code } catch (Exception e) { sender.sendMessage(e.message) } diff --git a/demo/src/test/resources/number-format-exception-command.groovy b/demo/src/test/resources/number-format-exception-command.groovy index ab77e553..9d1fa92a 100644 --- a/demo/src/test/resources/number-format-exception-command.groovy +++ b/demo/src/test/resources/number-format-exception-command.groovy @@ -2,6 +2,6 @@ def run = { sender, label, args -> try { sender.sendMessage("Your number is ${Integer.valueOf(args[0])}") } catch (NumberFormatException ignored) { - + // auto-generated code } } \ No newline at end of file From 33eb2b06924c66ea332cb9b6ed6790f4e5836658 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 15:19:37 +0200 Subject: [PATCH 199/204] Removed unnecessary def explication --- demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy index d87667e0..4604f25c 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -70,7 +70,7 @@ class YAGL extends JavaPlugin { * @param commandsDir the output directory */ void saveDefaultCommands(final @NotNull File commandsDir) { - final def resourceDir = '/commands' + final resourceDir = '/commands' FileUtils.createFolder(commandsDir) getClass().getResourceAsStream(resourceDir).withReader { reader -> String fileName From b247f26c6400344c21d7bb7725963dbbeae4a8a7 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 15:24:30 +0200 Subject: [PATCH 200/204] Refactored code --- .../main/groovy/it/angrybear/yagl/YAGL.groovy | 18 +++++++++--------- .../yagl/commands/ShellCommand.groovy | 1 + .../main/resources/commands/OpenDataGUI.groovy | 2 +- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy index 4604f25c..54a9027f 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/YAGL.groovy @@ -38,7 +38,7 @@ class YAGL extends JavaPlugin { if (!commandsDir.exists()) saveDefaultCommands(commandsDir) File[] files = commandsDir.listFiles() if (files != null) - this.commands.addAll(files.findAll({ it.name.endsWith('.groovy') }).collect { new ShellCommand(it) }) + this.commands.addAll(files.findAll { it.name.endsWith('.groovy') }.collect { new ShellCommand(it) }) commandMap().ifPresent { map -> this.commands.each { map.register(name, it) } } } @@ -57,13 +57,6 @@ class YAGL extends JavaPlugin { }) } - private static Optional commandMap() { - def pluginManager = Bukkit.pluginManager - // Terrible line, but necessary for JaCoCo coverage report to 100% - pluginManager == null ? Optional.empty() : Optional.ofNullable((CommandMap) new Refl<>(pluginManager) - .getFieldObject('commandMap')) - } - /** * Saves all the default command scripts to the given directory * @@ -84,7 +77,14 @@ class YAGL extends JavaPlugin { } } - private void writeResourceToFile(final @NotNull File dir, final @NotNull String fileName, final @NotNull resourceDir) { + private static Optional commandMap() { + def pluginManager = Bukkit.pluginManager + // Terrible line, but necessary for JaCoCo coverage report to 100% + pluginManager == null ? Optional.empty() : Optional.ofNullable((CommandMap) new Refl<>(pluginManager) + .getFieldObject('commandMap')) + } + + private static void writeResourceToFile(final @NotNull File dir, final @NotNull String fileName, final @NotNull resourceDir) { def file = new File(dir, fileName) if (file.exists()) FileUtils.deleteFile(file) FileUtils.createNewFile(file) diff --git a/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy b/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy index c09d2303..0bb880fa 100644 --- a/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy +++ b/demo/src/main/groovy/it/angrybear/yagl/commands/ShellCommand.groovy @@ -48,4 +48,5 @@ class ShellCommand extends Command { List tabComplete(@NotNull CommandSender sender, @NotNull String alias, @NotNull String[] args) throws IllegalArgumentException { return new ArrayList<>() } + } diff --git a/demo/src/main/resources/commands/OpenDataGUI.groovy b/demo/src/main/resources/commands/OpenDataGUI.groovy index b9767488..2ae4d64a 100644 --- a/demo/src/main/resources/commands/OpenDataGUI.groovy +++ b/demo/src/main/resources/commands/OpenDataGUI.groovy @@ -39,7 +39,7 @@ def run = { sender, label, args -> 'Alan', 'Grace', 'Juan', 'Amber', 'Albert', 'Denise', 'Willie', 'Danielle', 'Elijah', 'Marilyn', 'Wayne', 'Beverly', 'Randy', 'Charlotte', 'Vincent', 'Natalie', 'Mason', 'Theresa', 'Roy', 'Diana', 'Ralph', 'Brittany', 'Bobby', 'Doris', 'Russell', 'Kayla', - 'Bradley', 'Alexis', 'Philip', 'Lori', 'Eugene', 'Marie' + 'Bradley', 'Alexis', 'Philip', 'Lori', 'Eugene', 'Marie', ] Function converter = s -> ItemGUIContent.newInstance(Material.PLAYER_HEAD.name()) .setDisplayName("&e${s}'s head") From 0473ec48566df56691da54863e7e5d8da1b9adda Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 15:25:31 +0200 Subject: [PATCH 201/204] Fixed imports --- demo/src/main/resources/commands/PlayEffect.groovy | 7 ++++++- demo/src/main/resources/commands/PlayParticle.groovy | 8 +++++++- 2 files changed, 13 insertions(+), 2 deletions(-) diff --git a/demo/src/main/resources/commands/PlayEffect.groovy b/demo/src/main/resources/commands/PlayEffect.groovy index 86e8a963..d01e51a6 100644 --- a/demo/src/main/resources/commands/PlayEffect.groovy +++ b/demo/src/main/resources/commands/PlayEffect.groovy @@ -6,7 +6,12 @@ */ import it.angrybear.yagl.Color import it.angrybear.yagl.WrappersAdapter -import it.angrybear.yagl.particles.* +import it.angrybear.yagl.particles.ColorParticleOption +import it.angrybear.yagl.particles.LegacyParticleType +import it.angrybear.yagl.particles.MaterialDataOption +import it.angrybear.yagl.particles.Particle +import it.angrybear.yagl.particles.PotionParticleOption +import it.angrybear.yagl.particles.PrimitiveParticleOption import it.angrybear.yagl.wrappers.Potion import it.fulminazzo.fulmicollection.objects.Refl import org.bukkit.entity.Player diff --git a/demo/src/main/resources/commands/PlayParticle.groovy b/demo/src/main/resources/commands/PlayParticle.groovy index cb0a6863..02726437 100644 --- a/demo/src/main/resources/commands/PlayParticle.groovy +++ b/demo/src/main/resources/commands/PlayParticle.groovy @@ -7,7 +7,13 @@ import it.angrybear.yagl.Color import it.angrybear.yagl.ItemAdapter import it.angrybear.yagl.WrappersAdapter -import it.angrybear.yagl.particles.* +import it.angrybear.yagl.particles.BlockDataOption +import it.angrybear.yagl.particles.DustParticleOption +import it.angrybear.yagl.particles.DustTransitionParticleOption +import it.angrybear.yagl.particles.ItemParticleOption +import it.angrybear.yagl.particles.Particle +import it.angrybear.yagl.particles.ParticleType +import it.angrybear.yagl.particles.PrimitiveParticleOption import it.fulminazzo.fulmicollection.objects.Refl import org.bukkit.Location import org.bukkit.entity.Player From 28e4d38e8e61e6ed0dc7dbe0582fa83e4ce32e01 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 15:27:39 +0200 Subject: [PATCH 202/204] Added empty methods documentation --- .../test/java/it/angrybear/yagl/guis/PageableGUITest.java | 6 +++--- .../test/java/it/angrybear/yagl/parsers/MockGUIParser.java | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java b/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java index 65a610f6..23bc2adb 100644 --- a/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java +++ b/gui/base/src/test/java/it/angrybear/yagl/guis/PageableGUITest.java @@ -242,17 +242,17 @@ protected MockViewer(UUID uniqueId, String name) { @Override public void playSound(@NotNull Sound sound) { - + // } @Override public void sendMessage(@NotNull String message) { - + // } @Override public void executeCommand(@NotNull String command) { - + // } @Override diff --git a/gui/serializer/src/test/java/it/angrybear/yagl/parsers/MockGUIParser.java b/gui/serializer/src/test/java/it/angrybear/yagl/parsers/MockGUIParser.java index 87bdcaea..9a26c176 100644 --- a/gui/serializer/src/test/java/it/angrybear/yagl/parsers/MockGUIParser.java +++ b/gui/serializer/src/test/java/it/angrybear/yagl/parsers/MockGUIParser.java @@ -37,7 +37,7 @@ public static class MockGUI implements GUI { @Override public void open(@NotNull Viewer viewer) { - + // } @Override From 3d825bc14232961c480d77869f2268d604949435 Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 15:28:38 +0200 Subject: [PATCH 203/204] Removed unnecessary def declaration from static function --- demo/src/main/resources/commands/CreateRecipe.groovy | 6 +++--- demo/src/main/resources/commands/PlayEffect.groovy | 2 +- demo/src/main/resources/commands/PlayParticle.groovy | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/demo/src/main/resources/commands/CreateRecipe.groovy b/demo/src/main/resources/commands/CreateRecipe.groovy index 3efc3b77..ee252520 100644 --- a/demo/src/main/resources/commands/CreateRecipe.groovy +++ b/demo/src/main/resources/commands/CreateRecipe.groovy @@ -5,7 +5,7 @@ import it.angrybear.yagl.items.recipes.ShapedRecipe import it.angrybear.yagl.items.recipes.ShapelessRecipe import org.bukkit.entity.Player -static def shaped(sender, label, args, output, name) { +static shaped(sender, label, args, output, name) { try { def rows = Integer.valueOf(args[0]) def columns = Integer.valueOf(args[1]) @@ -22,7 +22,7 @@ static def shaped(sender, label, args, output, name) { } } -static def shapeless(sender, label, args, output, name) { +static shapeless(sender, label, args, output, name) { try { if (args.length == 0) throw new IndexOutOfBoundsException() BukkitItem.newRecipeItem(output) @@ -39,7 +39,7 @@ static def shapeless(sender, label, args, output, name) { } } -static def furnace(sender, label, args, output, name) { +static furnace(sender, label, args, output, name) { try { BukkitItem.newRecipeItem(output) .addRecipes(new FurnaceRecipe(name) diff --git a/demo/src/main/resources/commands/PlayEffect.groovy b/demo/src/main/resources/commands/PlayEffect.groovy index d01e51a6..7a4a5b1e 100644 --- a/demo/src/main/resources/commands/PlayEffect.groovy +++ b/demo/src/main/resources/commands/PlayEffect.groovy @@ -16,7 +16,7 @@ import it.angrybear.yagl.wrappers.Potion import it.fulminazzo.fulmicollection.objects.Refl import org.bukkit.entity.Player -static def getOption(sender, particleType, optionType, args) { +static getOption(sender, particleType, optionType, args) { if (optionType == PotionParticleOption) new PotionParticleOption(new Potion(args[0], Integer.valueOf(args[1]), Boolean.valueOf(args[2]), Boolean.valueOf(args[3]))) diff --git a/demo/src/main/resources/commands/PlayParticle.groovy b/demo/src/main/resources/commands/PlayParticle.groovy index 02726437..5d4de4d8 100644 --- a/demo/src/main/resources/commands/PlayParticle.groovy +++ b/demo/src/main/resources/commands/PlayParticle.groovy @@ -19,7 +19,7 @@ import org.bukkit.Location import org.bukkit.entity.Player import org.bukkit.inventory.EquipmentSlot -static def getOption(sender, particleType, optionType, args) { +static getOption(sender, particleType, optionType, args) { if (optionType == DustParticleOption) new DustParticleOption(Color.fromARGB(args[0]), Float.valueOf(args[1])) if (optionType == DustTransitionParticleOption) From 0e0faf96b85bcbc560adea21eeecc2651c6e263d Mon Sep 17 00:00:00 2001 From: Fulminazzo Date: Fri, 19 Apr 2024 18:46:31 +0200 Subject: [PATCH 204/204] Removed useless Javadocs --- .../main/java/it/angrybear/yagl/viewers/Viewer.java | 12 ------------ 1 file changed, 12 deletions(-) diff --git a/gui/base/src/main/java/it/angrybear/yagl/viewers/Viewer.java b/gui/base/src/main/java/it/angrybear/yagl/viewers/Viewer.java index be869bee..e3974ab6 100644 --- a/gui/base/src/main/java/it/angrybear/yagl/viewers/Viewer.java +++ b/gui/base/src/main/java/it/angrybear/yagl/viewers/Viewer.java @@ -12,21 +12,9 @@ */ @Getter public abstract class Viewer { - /** - * The Unique id. - */ protected final UUID uniqueId; - /** - * The Name. - */ protected final String name; - /** - * The Previous gui. - */ protected GUI previousGUI; - /** - * The Open gui. - */ protected GUI openGUI; /**