aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--settings.gradle15
-rw-r--r--spark-common/build.gradle32
-rw-r--r--spark-minestom/build.gradle51
-rw-r--r--spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomClassSourceLookup.java49
-rw-r--r--spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomCommandSender.java68
-rw-r--r--spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomPlatformInfo.java47
-rw-r--r--spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomPlayerPingProvider.java41
-rw-r--r--spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomSparkPlugin.java195
-rw-r--r--spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomTickHook.java47
-rw-r--r--spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomTickReporter.java48
-rw-r--r--spark-minestom/src/main/resources/extension.json5
-rw-r--r--spark-nukkit/build.gradle47
-rw-r--r--spark-nukkit/src/main/java/me/lucko/spark/nukkit/NukkitClassSourceLookup.java38
-rw-r--r--spark-nukkit/src/main/java/me/lucko/spark/nukkit/NukkitCommandSender.java59
-rw-r--r--spark-nukkit/src/main/java/me/lucko/spark/nukkit/NukkitPlatformInfo.java57
-rw-r--r--spark-nukkit/src/main/java/me/lucko/spark/nukkit/NukkitPlayerPingProvider.java45
-rw-r--r--spark-nukkit/src/main/java/me/lucko/spark/nukkit/NukkitSparkPlugin.java118
-rw-r--r--spark-nukkit/src/main/resources/plugin.yml10
-rw-r--r--spark-sponge/build.gradle (renamed from spark-sponge8/build.gradle)2
-rw-r--r--spark-sponge/src/main/java/me/lucko/spark/sponge/SpongeClassSourceLookup.java (renamed from spark-sponge8/src/main/java/me/lucko/spark/sponge/Sponge8ClassSourceLookup.java)4
-rw-r--r--spark-sponge/src/main/java/me/lucko/spark/sponge/SpongeCommandSender.java (renamed from spark-sponge8/src/main/java/me/lucko/spark/sponge/Sponge8CommandSender.java)8
-rw-r--r--spark-sponge/src/main/java/me/lucko/spark/sponge/SpongePlatformInfo.java (renamed from spark-sponge8/src/main/java/me/lucko/spark/sponge/Sponge8PlatformInfo.java)4
-rw-r--r--spark-sponge/src/main/java/me/lucko/spark/sponge/SpongePlayerPingProvider.java (renamed from spark-sponge8/src/main/java/me/lucko/spark/sponge/Sponge8PlayerPingProvider.java)4
-rw-r--r--spark-sponge/src/main/java/me/lucko/spark/sponge/SpongeSparkPlugin.java (renamed from spark-sponge8/src/main/java/me/lucko/spark/sponge/Sponge8SparkPlugin.java)28
-rw-r--r--spark-sponge/src/main/java/me/lucko/spark/sponge/SpongeTickHook.java (renamed from spark-sponge8/src/main/java/me/lucko/spark/sponge/Sponge8TickHook.java)4
-rw-r--r--spark-sponge/src/main/java/me/lucko/spark/sponge/SpongeWorldInfoProvider.java (renamed from spark-sponge8/src/main/java/me/lucko/spark/sponge/Sponge8WorldInfoProvider.java)4
-rw-r--r--spark-sponge/src/main/resources/META-INF/sponge_plugins.json (renamed from spark-sponge8/src/main/resources/META-INF/sponge_plugins.json)4
-rw-r--r--spark-sponge7/build.gradle46
-rw-r--r--spark-sponge7/src/main/java/me/lucko/spark/sponge/Sponge7ClassSourceLookup.java43
-rw-r--r--spark-sponge7/src/main/java/me/lucko/spark/sponge/Sponge7CommandSender.java59
-rw-r--r--spark-sponge7/src/main/java/me/lucko/spark/sponge/Sponge7PlatformInfo.java58
-rw-r--r--spark-sponge7/src/main/java/me/lucko/spark/sponge/Sponge7PlayerPingProvider.java45
-rw-r--r--spark-sponge7/src/main/java/me/lucko/spark/sponge/Sponge7SparkPlugin.java232
-rw-r--r--spark-sponge7/src/main/java/me/lucko/spark/sponge/Sponge7TickHook.java50
-rw-r--r--spark-sponge7/src/main/java/me/lucko/spark/sponge/Sponge7WorldInfoProvider.java123
-rw-r--r--spark-velocity4/build.gradle52
-rw-r--r--spark-velocity4/src/main/java/me/lucko/spark/velocity/Velocity4ClassSourceLookup.java61
-rw-r--r--spark-velocity4/src/main/java/me/lucko/spark/velocity/Velocity4CommandSender.java64
-rw-r--r--spark-velocity4/src/main/java/me/lucko/spark/velocity/Velocity4PlatformInfo.java57
-rw-r--r--spark-velocity4/src/main/java/me/lucko/spark/velocity/Velocity4PlayerPingProvider.java45
-rw-r--r--spark-velocity4/src/main/java/me/lucko/spark/velocity/Velocity4SparkPlugin.java161
-rw-r--r--spark-waterdog/build.gradle56
-rw-r--r--spark-waterdog/src/main/java/me/lucko/spark/waterdog/WaterdogClassSourceLookup.java61
-rw-r--r--spark-waterdog/src/main/java/me/lucko/spark/waterdog/WaterdogCommandSender.java59
-rw-r--r--spark-waterdog/src/main/java/me/lucko/spark/waterdog/WaterdogPlatformInfo.java52
-rw-r--r--spark-waterdog/src/main/java/me/lucko/spark/waterdog/WaterdogPlayerPingProvider.java45
-rw-r--r--spark-waterdog/src/main/java/me/lucko/spark/waterdog/WaterdogSparkPlugin.java139
-rw-r--r--spark-waterdog/src/main/resources/plugin.yml6
48 files changed, 66 insertions, 2482 deletions
diff --git a/settings.gradle b/settings.gradle
index 6931c9f..d3e1b45 100644
--- a/settings.gradle
+++ b/settings.gradle
@@ -23,18 +23,13 @@ plugins {
rootProject.name = 'spark'
include (
'spark-api',
- 'spark-common',
'spark-bukkit',
- 'spark-paper',
'spark-bungeecord',
- 'spark-velocity',
- 'spark-velocity4',
- 'spark-sponge7',
- 'spark-sponge8',
+ 'spark-common',
+ 'spark-fabric',
'spark-forge',
'spark-neoforge',
- 'spark-fabric',
- 'spark-nukkit',
- 'spark-waterdog',
- //'spark-minestom', // disabled until minestom publish their maven artifacts to a proper repo
+ 'spark-paper',
+ 'spark-sponge',
+ 'spark-velocity',
)
diff --git a/spark-common/build.gradle b/spark-common/build.gradle
index 5bc4bda..ba3d2b4 100644
--- a/spark-common/build.gradle
+++ b/spark-common/build.gradle
@@ -1,5 +1,6 @@
plugins {
id 'com.google.protobuf' version '0.9.4'
+ id 'maven-publish'
}
license {
@@ -14,7 +15,7 @@ dependencies {
implementation 'com.github.jvm-profiling-tools:async-profiler:v2.8.3'
implementation 'org.ow2.asm:asm:9.7'
implementation 'net.bytebuddy:byte-buddy-agent:1.14.17'
- implementation 'com.google.protobuf:protobuf-javalite:4.27.1'
+ implementation 'com.google.protobuf:protobuf-javalite:4.28.2'
implementation('me.lucko:bytesocks-java-client:1.0-20230828.145440-5') {
exclude(module: 'slf4j-api')
@@ -60,7 +61,7 @@ dependencies {
protobuf {
protoc {
- artifact = 'com.google.protobuf:protoc:4.27.1'
+ artifact = 'com.google.protobuf:protoc:4.28.2'
}
generateProtoTasks {
all().each { task ->
@@ -77,3 +78,30 @@ test {
useJUnitPlatform {}
systemProperty('net.kyori.ansi.colorLevel', 'indexed16')
}
+
+publishing {
+ //repositories {
+ // maven {
+ // url = 'https://oss.sonatype.org/content/repositories/snapshots'
+ // credentials {
+ // username = sonatypeUsername
+ // password = sonatypePassword
+ // }
+ // }
+ //}
+ //repositories {
+ // maven {
+ // url = 'https://nexus.lucko.me/repository/maven-snapshots/'
+ // credentials {
+ // username = luckoNexusUsername
+ // password = luckoNexusPassword
+ // }
+ // }
+ //}
+ publications {
+ maven(MavenPublication) {
+ from components.java
+ version = "${project.pluginVersion}-SNAPSHOT"
+ }
+ }
+}
diff --git a/spark-minestom/build.gradle b/spark-minestom/build.gradle
deleted file mode 100644
index 6e0d7e6..0000000
--- a/spark-minestom/build.gradle
+++ /dev/null
@@ -1,51 +0,0 @@
-plugins {
- id 'com.gradleup.shadow' version '8.3.0'
-}
-
-tasks.withType(JavaCompile) {
- // override, compile targeting J17
- options.release = 17
-}
-
-dependencies {
- implementation project(':spark-common')
- compileOnly 'com.github.Minestom.Minestom:Minestom:master-SNAPSHOT'
- implementation 'com.google.guava:guava:19.0'
-}
-
-processResources {
- from(sourceSets.main.resources.srcDirs) {
- expand (
- 'pluginVersion': project.pluginVersion,
- 'pluginDescription': project.pluginDescription
- )
- include 'extension.json'
- }
-}
-
-shadowJar {
- archiveFileName = "spark-${project.pluginVersion}-minestom.jar"
-
- dependencies {
- exclude(dependency('net.kyori:^(?!adventure-text-feature-pagination).+$'))
- }
-
- relocate 'net.kyori.adventure.text.feature.pagination', 'me.lucko.spark.lib.adventure.pagination'
- relocate 'net.bytebuddy', 'me.lucko.spark.lib.bytebuddy'
- relocate 'com.google.protobuf', 'me.lucko.spark.lib.protobuf'
- relocate 'org.objectweb.asm', 'me.lucko.spark.lib.asm'
- relocate 'one.profiler', 'me.lucko.spark.lib.asyncprofiler'
- relocate 'me.lucko.bytesocks.client', 'me.lucko.spark.lib.bytesocks'
- relocate 'org.java_websocket', 'me.lucko.spark.lib.bytesocks.ws'
-
- exclude 'module-info.class'
- exclude 'META-INF/maven/**'
- exclude 'META-INF/proguard/**'
- exclude '**/*.proto'
- exclude '**/*.proto.bin'
-}
-
-artifacts {
- archives shadowJar
- shadow shadowJar
-}
diff --git a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomClassSourceLookup.java b/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomClassSourceLookup.java
deleted file mode 100644
index ca44eea..0000000
--- a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomClassSourceLookup.java
+++ /dev/null
@@ -1,49 +0,0 @@
-/*
- * This file is part of spark.
- *
- * Copyright (c) lucko (Luck) <luck@lucko.me>
- * Copyright (c) contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-package me.lucko.spark.minestom;
-
-import me.lucko.spark.common.sampler.source.ClassSourceLookup;
-
-import net.minestom.server.MinecraftServer;
-import net.minestom.server.extensions.Extension;
-import net.minestom.server.extensions.ExtensionClassLoader;
-
-import java.util.HashMap;
-import java.util.Map;
-
-public class MinestomClassSourceLookup extends ClassSourceLookup.ByClassLoader {
- private final Map<ClassLoader, String> classLoaderToExtensions;
-
- public MinestomClassSourceLookup() {
- this.classLoaderToExtensions = new HashMap<>();
- for (Extension extension : MinecraftServer.getExtensionManager().getExtensions()) {
- this.classLoaderToExtensions.put(extension.getClass().getClassLoader(), extension.getOrigin().getName());
- }
- }
-
- @Override
- public String identify(ClassLoader loader) {
- if (loader instanceof ExtensionClassLoader) {
- return this.classLoaderToExtensions.get(loader);
- }
- return null;
- }
-}
diff --git a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomCommandSender.java b/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomCommandSender.java
deleted file mode 100644
index e4323e6..0000000
--- a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomCommandSender.java
+++ /dev/null
@@ -1,68 +0,0 @@
-/*
- * This file is part of spark.
- *
- * Copyright (c) lucko (Luck) <luck@lucko.me>
- * Copyright (c) contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-package me.lucko.spark.minestom;
-
-import me.lucko.spark.common.command.sender.AbstractCommandSender;
-
-import net.kyori.adventure.text.Component;
-import net.minestom.server.command.CommandSender;
-import net.minestom.server.command.ConsoleSender;
-import net.minestom.server.entity.Player;
-
-import java.util.UUID;
-
-public class MinestomCommandSender extends AbstractCommandSender<CommandSender> {
- public MinestomCommandSender(CommandSender delegate) {
- super(delegate);
- }
-
- @Override
- public String getName() {
- if (this.delegate instanceof Player player) {
- return player.getUsername();
- } else if (this.delegate instanceof ConsoleSender) {
- return "Console";
- }else {
- return "unknown:" + this.delegate.getClass().getSimpleName();
- }
- }
-
- @Override
- public UUID getUniqueId() {
- if (super.delegate instanceof Player player) {
- return player.getUuid();
- }
- return null;
- }
-
- @Override
- public void sendMessage(Component message) {
- this.delegate.sendMessage(message);
- }
-
- @Override
- public boolean hasPermission(String permission) {
- if (this.delegate instanceof ConsoleSender) {
- return true;
- }
- return this.delegate.hasPermission(permission);
- }
-}
diff --git a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomPlatformInfo.java b/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomPlatformInfo.java
deleted file mode 100644
index add258a..0000000
--- a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomPlatformInfo.java
+++ /dev/null
@@ -1,47 +0,0 @@
-/*
- * This file is part of spark.
- *
- * Copyright (c) lucko (Luck) <luck@lucko.me>
- * Copyright (c) contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-package me.lucko.spark.minestom;
-
-import me.lucko.spark.common.platform.PlatformInfo;
-
-import net.minestom.server.MinecraftServer;
-
-public class MinestomPlatformInfo implements PlatformInfo {
- @Override
- public Type getType() {
- return Type.SERVER;
- }
-
- @Override
- public String getName() {
- return "Minestom";
- }
-
- @Override
- public String getVersion() {
- return MinecraftServer.VERSION_NAME + "-" + MinecraftServer.getBrandName();
- }
-
- @Override
- public String getMinecraftVersion() {
- return MinecraftServer.VERSION_NAME;
- }
-}
diff --git a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomPlayerPingProvider.java b/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomPlayerPingProvider.java
deleted file mode 100644
index 0b50c0a..0000000
--- a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomPlayerPingProvider.java
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- * This file is part of spark.
- *
- * Copyright (c) lucko (Luck) <luck@lucko.me>
- * Copyright (c) contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-package me.lucko.spark.minestom;
-
-import com.google.common.collect.ImmutableMap;
-
-import me.lucko.spark.common.monitor.ping.PlayerPingProvider;
-
-import net.minestom.server.MinecraftServer;
-import net.minestom.server.entity.Player;
-
-import java.util.Map;
-
-public class MinestomPlayerPingProvider implements PlayerPingProvider {
- @Override
- public Map<String, Integer> poll() {
- ImmutableMap.Builder<String, Integer> builder = ImmutableMap.builder();
- for (Player player : MinecraftServer.getConnectionManager().getOnlinePlayers()) {
- builder.put(player.getUsername(), player.getLatency());
- }
- return builder.build();
- }
-}
diff --git a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomSparkPlugin.java b/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomSparkPlugin.java
deleted file mode 100644
index 9014476..0000000
--- a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomSparkPlugin.java
+++ /dev/null
@@ -1,195 +0,0 @@
-/*
- * This file is part of spark.
- *
- * Copyright (c) lucko (Luck) <luck@lucko.me>
- * Copyright (c) contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-package me.lucko.spark.minestom;
-
-import me.lucko.spark.common.SparkPlatform;
-import me.lucko.spark.common.SparkPlugin;
-import me.lucko.spark.common.monitor.ping.PlayerPingProvider;
-import me.lucko.spark.common.platform.PlatformInfo;
-import me.lucko.spark.common.sampler.source.ClassSourceLookup;
-import me.lucko.spark.common.sampler.source.SourceMetadata;
-import me.lucko.spark.common.tick.TickHook;
-import me.lucko.spark.common.tick.TickReporter;
-
-import net.minestom.server.MinecraftServer;
-import net.minestom.server.command.CommandSender;
-import net.minestom.server.command.builder.Command;
-import net.minestom.server.command.builder.CommandContext;
-import net.minestom.server.command.builder.CommandExecutor;
-import net.minestom.server.command.builder.arguments.ArgumentStringArray;
-import net.minestom.server.command.builder.arguments.ArgumentType;
-import net.minestom.server.command.builder.suggestion.Suggestion;
-import net.minestom.server.command.builder.suggestion.SuggestionCallback;
-import net.minestom.server.command.builder.suggestion.SuggestionEntry;
-import net.minestom.server.extensions.Extension;
-import net.minestom.server.timer.ExecutionType;
-
-import org.jetbrains.annotations.NotNull;
-
-import java.nio.file.Path;
-import java.util.Arrays;
-import java.util.Collection;
-import java.util.logging.Level;
-import java.util.stream.Stream;
-
-public class MinestomSparkPlugin extends Extension implements SparkPlugin {
- private SparkPlatform platform;
- private MinestomSparkCommand command;
-
- @Override
- public void initialize() {
- this.platform = new SparkPlatform(this);
- this.platform.enable();
- this.command = new MinestomSparkCommand(this.platform);
- MinecraftServer.getCommandManager().register(this.command);
- }
-
- @Override
- public void terminate() {
- this.platform.disable();
- MinecraftServer.getCommandManager().unregister(this.command);
- }
-
- @Override
- public String getVersion() {
- return getOrigin().getVersion();
- }
-
- @Override
- public Path getPluginDirectory() {
- return getDataDirectory();
- }
-
- @Override
- public String getCommandName() {
- return "spark";
- }
-
- @Override
- public Stream<MinestomCommandSender> getCommandSenders() {
- return Stream.concat(
- MinecraftServer.getConnectionManager().getOnlinePlayers().stream(),
- Stream.of(MinecraftServer.getCommandManager().getConsoleSender())
- ).map(MinestomCommandSender::new);
- }
-
- @Override
- public void executeAsync(Runnable task) {
- MinecraftServer.getSchedulerManager().scheduleNextTick(task, ExecutionType.ASYNC);
- }
-
- @Override
- public void log(Level level, String msg) {
- if (level == Level.INFO) {
- this.getLogger().info(msg);
- } else if (level == Level.WARNING) {
- this.getLogger().warn(msg);
- } else if (level == Level.SEVERE) {
- this.getLogger().error(msg);
- } else {
- throw new IllegalArgumentException(level.getName());
- }
- }
-
- @Override
- public PlatformInfo getPlatformInfo() {
- return new MinestomPlatformInfo();
- }
-
- @Override
- public ClassSourceLookup createClassSourceLookup() {
- return new MinestomClassSourceLookup();
- }
-
- @Override
- public Collection<SourceMetadata> getKnownSources() {
- return SourceMetadata.gather(
- MinecraftServer.getExtensionManager().getExtensions(),
- extension -> extension.getOrigin().getName(),
- extension -> extension.getOrigin().getVersion(),
- extension -> String.join(", ", extension.getOrigin().getAuthors())
- );
- }
-
- @Override
- public PlayerPingProvider createPlayerPingProvider() {
- return new MinestomPlayerPingProvider();
- }
-
- @Override
- public TickReporter createTickReporter() {
- return new MinestomTickReporter();
- }
-
- @Override
- public TickHook createTickHook() {
- return new MinestomTickHook();
- }
-
- private static final class MinestomSparkCommand extends Command implements CommandExecutor, SuggestionCallback {
- private final SparkPlatform platform;
-
- public MinestomSparkCommand(SparkPlatform platform) {
- super("spark");
- this.platform = platform;
-
- ArgumentStringArray arrayArgument = ArgumentType.StringArray("args");
- arrayArgument.setSuggestionCallback(this);
-
- addSyntax(this, arrayArgument);
- setDefaultExecutor((sender, context) -> platform.executeCommand(new MinestomCommandSender(sender), new String[0]));
- }
-
- // execute
- @Override
- public void apply(@NotNull CommandSender sender, @NotNull CommandContext context) {
- String[] args = processArgs(context, false);
- if (args == null) {
- return;
- }
-
- this.platform.executeCommand(new MinestomCommandSender(sender), args);
- }
-
- // tab complete
- @Override
- public void apply(@NotNull CommandSender sender, @NotNull CommandContext context, @NotNull Suggestion suggestion) {
- String[] args = processArgs(context, true);
- if (args == null) {
- return;
- }
-
- Iterable<String> suggestionEntries = this.platform.tabCompleteCommand(new MinestomCommandSender(sender), args);
- for (String suggestionEntry : suggestionEntries) {
- suggestion.addEntry(new SuggestionEntry(suggestionEntry));
- }
- }
-
- private static String [] processArgs(CommandContext context, boolean tabComplete) {
- String[] split = context.getInput().split(" ", tabComplete ? -1 : 0);
- if (split.length == 0 || !split[0].equals("/spark") && !split[0].equals("spark")) {
- return null;
- }
-
- return Arrays.copyOfRange(split, 1, split.length);
- }
- }
-}
diff --git a/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomTickHook.java b/spark-minestom/src/main/java/me/lucko/spark/minestom/MinestomTickHook.java
deleted file mode 100644
index 44c1c2d..0000000
--- a/