mirror of
https://github.com/PlaceholderAPI/PlaceholderAPI
synced 2024-11-18 00:46:55 +01:00
Format to Daddy code style
This commit is contained in:
parent
cee6984818
commit
dcc8dad4ea
@ -225,8 +225,7 @@ public final class PlaceholderAPI {
|
|||||||
@NotNull
|
@NotNull
|
||||||
@Deprecated
|
@Deprecated
|
||||||
@ApiStatus.ScheduledForRemoval(inVersion = "2.11.0")
|
@ApiStatus.ScheduledForRemoval(inVersion = "2.11.0")
|
||||||
public static Map<String, PlaceholderHook> getPlaceholders()
|
public static Map<String, PlaceholderHook> getPlaceholders() {
|
||||||
{
|
|
||||||
return PlaceholderAPIPlugin.getInstance().getLocalExpansionManager()
|
return PlaceholderAPIPlugin.getInstance().getLocalExpansionManager()
|
||||||
.getExpansions().stream()
|
.getExpansions().stream()
|
||||||
.collect(Collectors.toMap(PlaceholderExpansion::getIdentifier, ex -> ex));
|
.collect(Collectors.toMap(PlaceholderExpansion::getIdentifier, ex -> ex));
|
||||||
|
@ -20,6 +20,10 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi;
|
package me.clip.placeholderapi;
|
||||||
|
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.logging.Level;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommandRouter;
|
import me.clip.placeholderapi.commands.PlaceholderCommandRouter;
|
||||||
import me.clip.placeholderapi.configuration.PlaceholderAPIConfig;
|
import me.clip.placeholderapi.configuration.PlaceholderAPIConfig;
|
||||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||||
@ -36,42 +40,31 @@ import org.bukkit.event.HandlerList;
|
|||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.text.SimpleDateFormat;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.logging.Level;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Yes I have a shit load of work to do...
|
* Yes I have a shit load of work to do...
|
||||||
*
|
*
|
||||||
* @author Ryan McCarthy
|
* @author Ryan McCarthy
|
||||||
*/
|
*/
|
||||||
public final class PlaceholderAPIPlugin extends JavaPlugin
|
public final class PlaceholderAPIPlugin extends JavaPlugin {
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final Version VERSION;
|
private static final Version VERSION;
|
||||||
|
private static PlaceholderAPIPlugin instance;
|
||||||
|
|
||||||
static
|
static {
|
||||||
{
|
|
||||||
final String version = Bukkit.getServer().getClass().getPackage().getName().split("\\.")[3];
|
final String version = Bukkit.getServer().getClass().getPackage().getName().split("\\.")[3];
|
||||||
|
|
||||||
boolean isSpigot;
|
boolean isSpigot;
|
||||||
try
|
try {
|
||||||
{
|
|
||||||
Class.forName("org.spigotmc.SpigotConfig");
|
Class.forName("org.spigotmc.SpigotConfig");
|
||||||
isSpigot = true;
|
isSpigot = true;
|
||||||
}
|
} catch (final ExceptionInInitializerError | ClassNotFoundException ignored) {
|
||||||
catch (final ExceptionInInitializerError | ClassNotFoundException ignored)
|
|
||||||
{
|
|
||||||
isSpigot = false;
|
isSpigot = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
VERSION = new Version(version, isSpigot);
|
VERSION = new Version(version, isSpigot);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static PlaceholderAPIPlugin instance;
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final PlaceholderAPIConfig config = new PlaceholderAPIConfig(this);
|
private final PlaceholderAPIConfig config = new PlaceholderAPIConfig(this);
|
||||||
|
|
||||||
@ -80,139 +73,6 @@ public final class PlaceholderAPIPlugin extends JavaPlugin
|
|||||||
@NotNull
|
@NotNull
|
||||||
private final CloudExpansionManager cloudExpansionManager = new CloudExpansionManager(this);
|
private final CloudExpansionManager cloudExpansionManager = new CloudExpansionManager(this);
|
||||||
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onLoad()
|
|
||||||
{
|
|
||||||
instance = this;
|
|
||||||
|
|
||||||
saveDefaultConfig();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onEnable()
|
|
||||||
{
|
|
||||||
setupCommand();
|
|
||||||
setupMetrics();
|
|
||||||
setupExpansions();
|
|
||||||
|
|
||||||
if (config.isCloudEnabled())
|
|
||||||
{
|
|
||||||
getCloudExpansionManager().load();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (config.checkUpdates())
|
|
||||||
{
|
|
||||||
new UpdateChecker(this).fetch();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onDisable()
|
|
||||||
{
|
|
||||||
getCloudExpansionManager().kill();
|
|
||||||
getLocalExpansionManager().kill();
|
|
||||||
|
|
||||||
HandlerList.unregisterAll(this);
|
|
||||||
|
|
||||||
Bukkit.getScheduler().cancelTasks(this);
|
|
||||||
|
|
||||||
instance = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public void reloadConf(@NotNull final CommandSender sender)
|
|
||||||
{
|
|
||||||
getLocalExpansionManager().kill();
|
|
||||||
|
|
||||||
reloadConfig();
|
|
||||||
|
|
||||||
getLocalExpansionManager().load(sender);
|
|
||||||
|
|
||||||
if (config.isCloudEnabled())
|
|
||||||
{
|
|
||||||
getCloudExpansionManager().load();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
getCloudExpansionManager().kill();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
public LocalExpansionManager getLocalExpansionManager()
|
|
||||||
{
|
|
||||||
return localExpansionManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
public CloudExpansionManager getCloudExpansionManager()
|
|
||||||
{
|
|
||||||
return cloudExpansionManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Obtain the configuration class for PlaceholderAPI.
|
|
||||||
*
|
|
||||||
* @return PlaceholderAPIConfig instance
|
|
||||||
*/
|
|
||||||
@NotNull
|
|
||||||
public PlaceholderAPIConfig getPlaceholderAPIConfig()
|
|
||||||
{
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private void setupCommand()
|
|
||||||
{
|
|
||||||
final PluginCommand pluginCommand = getCommand("placeholderapi");
|
|
||||||
if (pluginCommand == null)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
final PlaceholderCommandRouter router = new PlaceholderCommandRouter(this);
|
|
||||||
pluginCommand.setExecutor(router);
|
|
||||||
pluginCommand.setTabCompleter(router);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setupMetrics()
|
|
||||||
{
|
|
||||||
final Metrics metrics = new Metrics(this);
|
|
||||||
metrics.addCustomChart(new Metrics.SimplePie("using_expansion_cloud", () -> getPlaceholderAPIConfig().isCloudEnabled() ? "yes" : "no"));
|
|
||||||
|
|
||||||
metrics.addCustomChart(new Metrics.SimplePie("using_spigot", () -> getServerVersion().isSpigot() ? "yes" : "no"));
|
|
||||||
|
|
||||||
metrics.addCustomChart(new Metrics.AdvancedPie("expansions_used", () -> {
|
|
||||||
final Map<String, Integer> values = new HashMap<>();
|
|
||||||
|
|
||||||
for (final PlaceholderExpansion expansion : getLocalExpansionManager().getExpansions())
|
|
||||||
{
|
|
||||||
values.put(expansion.getRequiredPlugin() == null ? expansion.getIdentifier() : expansion.getRequiredPlugin(), 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
return values;
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setupExpansions()
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().registerEvents(getLocalExpansionManager(), this);
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
Class.forName("org.bukkit.event.server.ServerLoadEvent");
|
|
||||||
new ServerLoadEventListener(this);
|
|
||||||
}
|
|
||||||
catch (final ExceptionInInitializerError | ClassNotFoundException ignored)
|
|
||||||
{
|
|
||||||
Bukkit.getScheduler().runTaskLater(this, () -> getLocalExpansionManager().load(Bukkit.getConsoleSender()), 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the static instance of the main class for PlaceholderAPI. This class is not the actual API
|
* Gets the static instance of the main class for PlaceholderAPI. This class is not the actual API
|
||||||
* class, this is the main class that extends JavaPlugin. For most API methods, use static methods
|
* class, this is the main class that extends JavaPlugin. For most API methods, use static methods
|
||||||
@ -221,20 +81,17 @@ public final class PlaceholderAPIPlugin extends JavaPlugin
|
|||||||
* @return PlaceholderAPIPlugin instance
|
* @return PlaceholderAPIPlugin instance
|
||||||
*/
|
*/
|
||||||
@NotNull
|
@NotNull
|
||||||
public static PlaceholderAPIPlugin getInstance()
|
public static PlaceholderAPIPlugin getInstance() {
|
||||||
{
|
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the configurable {@linkplain String} value that should be returned when a boolean is true
|
* Get the configurable {@linkplain String} value that should be returned when a boolean is true
|
||||||
*
|
*
|
||||||
* @return string value of true
|
* @return string value of true
|
||||||
*/
|
*/
|
||||||
@NotNull
|
@NotNull
|
||||||
public static String booleanTrue()
|
public static String booleanTrue() {
|
||||||
{
|
|
||||||
return getInstance().getPlaceholderAPIConfig().booleanTrue();
|
return getInstance().getPlaceholderAPIConfig().booleanTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -244,8 +101,7 @@ public final class PlaceholderAPIPlugin extends JavaPlugin
|
|||||||
* @return string value of false
|
* @return string value of false
|
||||||
*/
|
*/
|
||||||
@NotNull
|
@NotNull
|
||||||
public static String booleanFalse()
|
public static String booleanFalse() {
|
||||||
{
|
|
||||||
return getInstance().getPlaceholderAPIConfig().booleanFalse();
|
return getInstance().getPlaceholderAPIConfig().booleanFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -256,23 +112,128 @@ public final class PlaceholderAPIPlugin extends JavaPlugin
|
|||||||
* @return date format
|
* @return date format
|
||||||
*/
|
*/
|
||||||
@NotNull
|
@NotNull
|
||||||
public static SimpleDateFormat getDateFormat()
|
public static SimpleDateFormat getDateFormat() {
|
||||||
{
|
try {
|
||||||
try
|
|
||||||
{
|
|
||||||
return new SimpleDateFormat(getInstance().getPlaceholderAPIConfig().dateFormat());
|
return new SimpleDateFormat(getInstance().getPlaceholderAPIConfig().dateFormat());
|
||||||
}
|
} catch (final IllegalArgumentException ex) {
|
||||||
catch (final IllegalArgumentException ex)
|
|
||||||
{
|
|
||||||
getInstance().getLogger().log(Level.WARNING, "configured date format is invalid", ex);
|
getInstance().getLogger().log(Level.WARNING, "configured date format is invalid", ex);
|
||||||
return new SimpleDateFormat("MM/dd/yy HH:mm:ss");
|
return new SimpleDateFormat("MM/dd/yy HH:mm:ss");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Version getServerVersion() {
|
||||||
public static Version getServerVersion()
|
|
||||||
{
|
|
||||||
return VERSION;
|
return VERSION;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onLoad() {
|
||||||
|
instance = this;
|
||||||
|
|
||||||
|
saveDefaultConfig();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
setupCommand();
|
||||||
|
setupMetrics();
|
||||||
|
setupExpansions();
|
||||||
|
|
||||||
|
if (config.isCloudEnabled()) {
|
||||||
|
getCloudExpansionManager().load();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (config.checkUpdates()) {
|
||||||
|
new UpdateChecker(this).fetch();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDisable() {
|
||||||
|
getCloudExpansionManager().kill();
|
||||||
|
getLocalExpansionManager().kill();
|
||||||
|
|
||||||
|
HandlerList.unregisterAll(this);
|
||||||
|
|
||||||
|
Bukkit.getScheduler().cancelTasks(this);
|
||||||
|
|
||||||
|
instance = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void reloadConf(@NotNull final CommandSender sender) {
|
||||||
|
getLocalExpansionManager().kill();
|
||||||
|
|
||||||
|
reloadConfig();
|
||||||
|
|
||||||
|
getLocalExpansionManager().load(sender);
|
||||||
|
|
||||||
|
if (config.isCloudEnabled()) {
|
||||||
|
getCloudExpansionManager().load();
|
||||||
|
} else {
|
||||||
|
getCloudExpansionManager().kill();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
public LocalExpansionManager getLocalExpansionManager() {
|
||||||
|
return localExpansionManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
public CloudExpansionManager getCloudExpansionManager() {
|
||||||
|
return cloudExpansionManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Obtain the configuration class for PlaceholderAPI.
|
||||||
|
*
|
||||||
|
* @return PlaceholderAPIConfig instance
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
public PlaceholderAPIConfig getPlaceholderAPIConfig() {
|
||||||
|
return config;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupCommand() {
|
||||||
|
final PluginCommand pluginCommand = getCommand("placeholderapi");
|
||||||
|
if (pluginCommand == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
final PlaceholderCommandRouter router = new PlaceholderCommandRouter(this);
|
||||||
|
pluginCommand.setExecutor(router);
|
||||||
|
pluginCommand.setTabCompleter(router);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupMetrics() {
|
||||||
|
final Metrics metrics = new Metrics(this);
|
||||||
|
metrics.addCustomChart(new Metrics.SimplePie("using_expansion_cloud",
|
||||||
|
() -> getPlaceholderAPIConfig().isCloudEnabled() ? "yes" : "no"));
|
||||||
|
|
||||||
|
metrics.addCustomChart(
|
||||||
|
new Metrics.SimplePie("using_spigot", () -> getServerVersion().isSpigot() ? "yes" : "no"));
|
||||||
|
|
||||||
|
metrics.addCustomChart(new Metrics.AdvancedPie("expansions_used", () -> {
|
||||||
|
final Map<String, Integer> values = new HashMap<>();
|
||||||
|
|
||||||
|
for (final PlaceholderExpansion expansion : getLocalExpansionManager().getExpansions()) {
|
||||||
|
values.put(expansion.getRequiredPlugin() == null ? expansion.getIdentifier()
|
||||||
|
: expansion.getRequiredPlugin(), 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return values;
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupExpansions() {
|
||||||
|
Bukkit.getPluginManager().registerEvents(getLocalExpansionManager(), this);
|
||||||
|
|
||||||
|
try {
|
||||||
|
Class.forName("org.bukkit.event.server.ServerLoadEvent");
|
||||||
|
new ServerLoadEventListener(this);
|
||||||
|
} catch (final ExceptionInInitializerError | ClassNotFoundException ignored) {
|
||||||
|
Bukkit.getScheduler()
|
||||||
|
.runTaskLater(this, () -> getLocalExpansionManager().load(Bukkit.getConsoleSender()), 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -27,19 +27,17 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @deprecated This class will be completely removed in the next release, please use {@link me.clip.placeholderapi.expansion.PlaceholderExpansion}
|
* @deprecated This class will be completely removed in the next release, please use {@link
|
||||||
|
* me.clip.placeholderapi.expansion.PlaceholderExpansion}
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
@ApiStatus.NonExtendable
|
@ApiStatus.NonExtendable
|
||||||
@ApiStatus.ScheduledForRemoval(inVersion = "2.11.0")
|
@ApiStatus.ScheduledForRemoval(inVersion = "2.11.0")
|
||||||
public abstract class PlaceholderHook
|
public abstract class PlaceholderHook {
|
||||||
{
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public String onRequest(@Nullable final OfflinePlayer player, @NotNull final String params)
|
public String onRequest(@Nullable final OfflinePlayer player, @NotNull final String params) {
|
||||||
{
|
if (player != null && player.isOnline()) {
|
||||||
if (player != null && player.isOnline())
|
|
||||||
{
|
|
||||||
return onPlaceholderRequest((Player) player, params);
|
return onPlaceholderRequest((Player) player, params);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,12 +45,12 @@ public abstract class PlaceholderHook
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @deprecated This method will be completely removed, please use {@link me.clip.placeholderapi.expansion.PlaceholderExpansion#onRequest(OfflinePlayer, String)}
|
* @deprecated This method will be completely removed, please use {@link
|
||||||
|
* me.clip.placeholderapi.expansion.PlaceholderExpansion#onRequest(OfflinePlayer, String)}
|
||||||
*/
|
*/
|
||||||
@Nullable
|
@Nullable
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public String onPlaceholderRequest(@Nullable final Player player, @NotNull final String params)
|
public String onPlaceholderRequest(@Nullable final Player player, @NotNull final String params) {
|
||||||
{
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,18 +22,16 @@ package me.clip.placeholderapi.commands;
|
|||||||
|
|
||||||
import com.google.common.collect.ImmutableSet;
|
import com.google.common.collect.ImmutableSet;
|
||||||
import com.google.common.collect.Sets;
|
import com.google.common.collect.Sets;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.stream.Stream;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public abstract class PlaceholderCommand {
|
||||||
import java.util.Set;
|
|
||||||
import java.util.stream.Stream;
|
|
||||||
|
|
||||||
public abstract class PlaceholderCommand
|
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final String label;
|
private final String label;
|
||||||
@ -44,75 +42,66 @@ public abstract class PlaceholderCommand
|
|||||||
private String permission;
|
private String permission;
|
||||||
|
|
||||||
|
|
||||||
protected PlaceholderCommand(@NotNull final String label, @NotNull final String... alias)
|
protected PlaceholderCommand(@NotNull final String label, @NotNull final String... alias) {
|
||||||
{
|
|
||||||
this.label = label;
|
this.label = label;
|
||||||
this.alias = Sets.newHashSet(alias);
|
this.alias = Sets.newHashSet(alias);
|
||||||
|
|
||||||
setPermission("placeholderapi." + label);
|
setPermission("placeholderapi." + label);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
public static Stream<PlaceholderCommand> filterByPermission(@NotNull final CommandSender sender,
|
||||||
|
@NotNull final Stream<PlaceholderCommand> commands) {
|
||||||
|
return commands.filter(
|
||||||
|
target -> target.getPermission() == null || sender.hasPermission(target.getPermission()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void suggestByParameter(@NotNull final Stream<String> possible,
|
||||||
|
@NotNull final List<String> suggestions, @Nullable final String parameter) {
|
||||||
|
if (parameter == null) {
|
||||||
|
possible.forEach(suggestions::add);
|
||||||
|
} else {
|
||||||
|
possible.filter(suggestion -> suggestion.toLowerCase().startsWith(parameter.toLowerCase()))
|
||||||
|
.forEach(suggestions::add);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public final String getLabel()
|
public final String getLabel() {
|
||||||
{
|
|
||||||
return label;
|
return label;
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
public final Set<String> getAlias()
|
public final Set<String> getAlias() {
|
||||||
{
|
|
||||||
return ImmutableSet.copyOf(alias);
|
return ImmutableSet.copyOf(alias);
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
public final Set<String> getLabels()
|
public final Set<String> getLabels() {
|
||||||
{
|
|
||||||
return ImmutableSet.<String>builder().add(label).addAll(alias).build();
|
return ImmutableSet.<String>builder().add(label).addAll(alias).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public final String getPermission()
|
public final String getPermission() {
|
||||||
{
|
|
||||||
return permission;
|
return permission;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setPermission(@NotNull final String permission)
|
public void setPermission(@NotNull final String permission) {
|
||||||
{
|
|
||||||
this.permission = permission;
|
this.permission = permission;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
{
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
public static Stream<PlaceholderCommand> filterByPermission(@NotNull final CommandSender sender, @NotNull final Stream<PlaceholderCommand> commands)
|
|
||||||
{
|
|
||||||
return commands.filter(target -> target.getPermission() == null || sender.hasPermission(target.getPermission()));
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void suggestByParameter(@NotNull final Stream<String> possible, @NotNull final List<String> suggestions, @Nullable final String parameter)
|
|
||||||
{
|
|
||||||
if (parameter == null)
|
|
||||||
{
|
|
||||||
possible.forEach(suggestions::add);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
possible.filter(suggestion -> suggestion.toLowerCase().startsWith(parameter.toLowerCase())).forEach(suggestions::add);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,13 @@ package me.clip.placeholderapi.commands;
|
|||||||
|
|
||||||
import com.google.common.collect.ImmutableList;
|
import com.google.common.collect.ImmutableList;
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.stream.Stream;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.impl.cloud.CommandECloud;
|
import me.clip.placeholderapi.commands.impl.cloud.CommandECloud;
|
||||||
import me.clip.placeholderapi.commands.impl.local.CommandDump;
|
import me.clip.placeholderapi.commands.impl.local.CommandDump;
|
||||||
@ -41,11 +48,7 @@ import org.bukkit.command.TabCompleter;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.*;
|
public final class PlaceholderCommandRouter implements CommandExecutor, TabCompleter {
|
||||||
import java.util.stream.Stream;
|
|
||||||
|
|
||||||
public final class PlaceholderCommandRouter implements CommandExecutor, TabCompleter
|
|
||||||
{
|
|
||||||
|
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
private static final List<PlaceholderCommand> COMMANDS = ImmutableList.of(new CommandHelp(),
|
private static final List<PlaceholderCommand> COMMANDS = ImmutableList.of(new CommandHelp(),
|
||||||
@ -67,14 +70,12 @@ public final class PlaceholderCommandRouter implements CommandExecutor, TabCompl
|
|||||||
private final Map<String, PlaceholderCommand> commands;
|
private final Map<String, PlaceholderCommand> commands;
|
||||||
|
|
||||||
|
|
||||||
public PlaceholderCommandRouter(@NotNull final PlaceholderAPIPlugin plugin)
|
public PlaceholderCommandRouter(@NotNull final PlaceholderAPIPlugin plugin) {
|
||||||
{
|
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
|
|
||||||
final ImmutableMap.Builder<String, PlaceholderCommand> commands = ImmutableMap.builder();
|
final ImmutableMap.Builder<String, PlaceholderCommand> commands = ImmutableMap.builder();
|
||||||
|
|
||||||
for (final PlaceholderCommand command : COMMANDS)
|
for (final PlaceholderCommand command : COMMANDS) {
|
||||||
{
|
|
||||||
command.getLabels().forEach(label -> commands.put(label, command));
|
command.getLabels().forEach(label -> commands.put(label, command));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,13 +84,11 @@ public final class PlaceholderCommandRouter implements CommandExecutor, TabCompl
|
|||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onCommand(@NotNull final CommandSender sender, @NotNull final Command command, @NotNull final String alias, @NotNull final String[] args)
|
public boolean onCommand(@NotNull final CommandSender sender, @NotNull final Command command,
|
||||||
{
|
@NotNull final String alias, @NotNull final String[] args) {
|
||||||
if (args.length == 0)
|
if (args.length == 0) {
|
||||||
{
|
|
||||||
final PlaceholderCommand fallback = commands.get("version");
|
final PlaceholderCommand fallback = commands.get("version");
|
||||||
if (fallback != null)
|
if (fallback != null) {
|
||||||
{
|
|
||||||
fallback.evaluate(plugin, sender, "", Collections.emptyList());
|
fallback.evaluate(plugin, sender, "", Collections.emptyList());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -99,42 +98,42 @@ public final class PlaceholderCommandRouter implements CommandExecutor, TabCompl
|
|||||||
final String search = args[0].toLowerCase();
|
final String search = args[0].toLowerCase();
|
||||||
final PlaceholderCommand target = commands.get(search);
|
final PlaceholderCommand target = commands.get(search);
|
||||||
|
|
||||||
if (target == null)
|
if (target == null) {
|
||||||
{
|
|
||||||
Msg.msg(sender, "&cUnknown command &7" + search);
|
Msg.msg(sender, "&cUnknown command &7" + search);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
final String permission = target.getPermission();
|
final String permission = target.getPermission();
|
||||||
if (permission != null && !permission.isEmpty() && !sender.hasPermission(permission))
|
if (permission != null && !permission.isEmpty() && !sender.hasPermission(permission)) {
|
||||||
{
|
|
||||||
Msg.msg(sender, "&cYou do not have permission to do this!");
|
Msg.msg(sender, "&cYou do not have permission to do this!");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
target.evaluate(plugin, sender, search, Arrays.asList(Arrays.copyOfRange(args, 1, args.length)));
|
target
|
||||||
|
.evaluate(plugin, sender, search, Arrays.asList(Arrays.copyOfRange(args, 1, args.length)));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<String> onTabComplete(@NotNull final CommandSender sender, @NotNull final Command command, @NotNull final String alias, @NotNull final String[] args)
|
public List<String> onTabComplete(@NotNull final CommandSender sender,
|
||||||
{
|
@NotNull final Command command, @NotNull final String alias, @NotNull final String[] args) {
|
||||||
final List<String> suggestions = new ArrayList<>();
|
final List<String> suggestions = new ArrayList<>();
|
||||||
|
|
||||||
if (args.length > 1)
|
if (args.length > 1) {
|
||||||
{
|
|
||||||
final PlaceholderCommand target = this.commands.get(args[0].toLowerCase());
|
final PlaceholderCommand target = this.commands.get(args[0].toLowerCase());
|
||||||
|
|
||||||
if (target != null)
|
if (target != null) {
|
||||||
{
|
target.complete(plugin, sender, args[0].toLowerCase(),
|
||||||
target.complete(plugin, sender, args[0].toLowerCase(), Arrays.asList(Arrays.copyOfRange(args, 1, args.length)), suggestions);
|
Arrays.asList(Arrays.copyOfRange(args, 1, args.length)), suggestions);
|
||||||
}
|
}
|
||||||
|
|
||||||
return suggestions;
|
return suggestions;
|
||||||
}
|
}
|
||||||
|
|
||||||
final Stream<String> targets = PlaceholderCommand.filterByPermission(sender, commands.values().stream()).map(PlaceholderCommand::getLabels).flatMap(Collection::stream);
|
final Stream<String> targets = PlaceholderCommand
|
||||||
|
.filterByPermission(sender, commands.values().stream()).map(PlaceholderCommand::getLabels)
|
||||||
|
.flatMap(Collection::stream);
|
||||||
PlaceholderCommand.suggestByParameter(targets, suggestions, args.length == 0 ? null : args[0]);
|
PlaceholderCommand.suggestByParameter(targets, suggestions, args.length == 0 ? null : args[0]);
|
||||||
|
|
||||||
return suggestions;
|
return suggestions;
|
||||||
|
@ -22,6 +22,10 @@ package me.clip.placeholderapi.commands.impl.cloud;
|
|||||||
|
|
||||||
import com.google.common.collect.ImmutableList;
|
import com.google.common.collect.ImmutableList;
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.stream.Stream;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.util.Msg;
|
import me.clip.placeholderapi.util.Msg;
|
||||||
@ -29,16 +33,11 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.Collection;
|
public final class CommandECloud extends PlaceholderCommand {
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.stream.Stream;
|
|
||||||
|
|
||||||
public final class CommandECloud extends PlaceholderCommand
|
|
||||||
{
|
|
||||||
|
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
private static final List<PlaceholderCommand> COMMANDS = ImmutableList.of(new CommandECloudClear(),
|
private static final List<PlaceholderCommand> COMMANDS = ImmutableList
|
||||||
|
.of(new CommandECloudClear(),
|
||||||
new CommandECloudToggle(),
|
new CommandECloudToggle(),
|
||||||
new CommandECloudStatus(),
|
new CommandECloudStatus(),
|
||||||
new CommandECloudUpdate(),
|
new CommandECloudUpdate(),
|
||||||
@ -48,9 +47,9 @@ public final class CommandECloud extends PlaceholderCommand
|
|||||||
new CommandECloudExpansionList(),
|
new CommandECloudExpansionList(),
|
||||||
new CommandECloudExpansionPlaceholders());
|
new CommandECloudExpansionPlaceholders());
|
||||||
|
|
||||||
static
|
static {
|
||||||
{
|
COMMANDS
|
||||||
COMMANDS.forEach(command -> command.setPermission("placeholderapi.ecloud." + command.getLabel()));
|
.forEach(command -> command.setPermission("placeholderapi.ecloud." + command.getLabel()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@ -58,14 +57,12 @@ public final class CommandECloud extends PlaceholderCommand
|
|||||||
private final Map<String, PlaceholderCommand> commands;
|
private final Map<String, PlaceholderCommand> commands;
|
||||||
|
|
||||||
|
|
||||||
public CommandECloud()
|
public CommandECloud() {
|
||||||
{
|
|
||||||
super("ecloud");
|
super("ecloud");
|
||||||
|
|
||||||
final ImmutableMap.Builder<String, PlaceholderCommand> commands = ImmutableMap.builder();
|
final ImmutableMap.Builder<String, PlaceholderCommand> commands = ImmutableMap.builder();
|
||||||
|
|
||||||
for (final PlaceholderCommand command : COMMANDS)
|
for (final PlaceholderCommand command : COMMANDS) {
|
||||||
{
|
|
||||||
command.getLabels().forEach(label -> commands.put(label, command));
|
command.getLabels().forEach(label -> commands.put(label, command));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -74,10 +71,10 @@ public final class CommandECloud extends PlaceholderCommand
|
|||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.isEmpty())
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
{
|
if (params.isEmpty()) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&b&lPlaceholderAPI &8- &7eCloud Help Menu &8- ",
|
"&b&lPlaceholderAPI &8- &7eCloud Help Menu &8- ",
|
||||||
" ",
|
" ",
|
||||||
@ -106,21 +103,19 @@ public final class CommandECloud extends PlaceholderCommand
|
|||||||
final String search = params.get(0).toLowerCase();
|
final String search = params.get(0).toLowerCase();
|
||||||
final PlaceholderCommand target = commands.get(search);
|
final PlaceholderCommand target = commands.get(search);
|
||||||
|
|
||||||
if (target == null)
|
if (target == null) {
|
||||||
{
|
|
||||||
Msg.msg(sender, "&cUnknown command &7ecloud " + search);
|
Msg.msg(sender, "&cUnknown command &7ecloud " + search);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final String permission = target.getPermission();
|
final String permission = target.getPermission();
|
||||||
if (permission != null && !permission.isEmpty() && !sender.hasPermission(permission))
|
if (permission != null && !permission.isEmpty() && !sender.hasPermission(permission)) {
|
||||||
{
|
|
||||||
Msg.msg(sender, "&cYou do not have permission to do this!");
|
Msg.msg(sender, "&cYou do not have permission to do this!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(target instanceof CommandECloudToggle) && !plugin.getPlaceholderAPIConfig().isCloudEnabled())
|
if (!(target instanceof CommandECloudToggle) && !plugin.getPlaceholderAPIConfig()
|
||||||
{
|
.isCloudEnabled()) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cThe eCloud Manager is not enabled!");
|
"&cThe eCloud Manager is not enabled!");
|
||||||
return;
|
return;
|
||||||
@ -130,11 +125,12 @@ public final class CommandECloud extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.size() <= 1)
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
{
|
if (params.size() <= 1) {
|
||||||
final Stream<String> targets = filterByPermission(sender, commands.values().stream()).map(PlaceholderCommand::getLabels).flatMap(Collection::stream);
|
final Stream<String> targets = filterByPermission(sender, commands.values().stream())
|
||||||
|
.map(PlaceholderCommand::getLabels).flatMap(Collection::stream);
|
||||||
suggestByParameter(targets, suggestions, params.isEmpty() ? null : params.get(0));
|
suggestByParameter(targets, suggestions, params.isEmpty() ? null : params.get(0));
|
||||||
|
|
||||||
return; // send sub commands
|
return; // send sub commands
|
||||||
@ -143,8 +139,7 @@ public final class CommandECloud extends PlaceholderCommand
|
|||||||
final String search = params.get(0).toLowerCase();
|
final String search = params.get(0).toLowerCase();
|
||||||
final PlaceholderCommand target = commands.get(search);
|
final PlaceholderCommand target = commands.get(search);
|
||||||
|
|
||||||
if (target == null)
|
if (target == null) {
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.cloud;
|
package me.clip.placeholderapi.commands.impl.cloud;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.util.Msg;
|
import me.clip.placeholderapi.util.Msg;
|
||||||
@ -27,19 +28,16 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandECloudClear extends PlaceholderCommand {
|
||||||
|
|
||||||
public final class CommandECloudClear extends PlaceholderCommand
|
public CommandECloudClear() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandECloudClear()
|
|
||||||
{
|
|
||||||
super("clear");
|
super("clear");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
plugin.getCloudExpansionManager().clean();
|
plugin.getCloudExpansionManager().clean();
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&aThe eCloud cache has been cleared!");
|
"&aThe eCloud cache has been cleared!");
|
||||||
|
@ -20,6 +20,9 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.cloud;
|
package me.clip.placeholderapi.commands.impl.cloud;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.stream.Stream;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
||||||
@ -28,52 +31,41 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandECloudDownload extends PlaceholderCommand {
|
||||||
import java.util.Optional;
|
|
||||||
import java.util.stream.Stream;
|
|
||||||
|
|
||||||
public final class CommandECloudDownload extends PlaceholderCommand
|
public CommandECloudDownload() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandECloudDownload()
|
|
||||||
{
|
|
||||||
super("download");
|
super("download");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.isEmpty())
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
{
|
if (params.isEmpty()) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cYou must supply the name of an expansion.");
|
"&cYou must supply the name of an expansion.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final CloudExpansion expansion = plugin.getCloudExpansionManager().findCloudExpansionByName(params.get(0)).orElse(null);
|
final CloudExpansion expansion = plugin.getCloudExpansionManager()
|
||||||
if (expansion == null)
|
.findCloudExpansionByName(params.get(0)).orElse(null);
|
||||||
{
|
if (expansion == null) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cFailed to find an expansion named: &f" + params.get(0));
|
"&cFailed to find an expansion named: &f" + params.get(0));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final CloudExpansion.Version version;
|
final CloudExpansion.Version version;
|
||||||
if (params.size() < 2)
|
if (params.size() < 2) {
|
||||||
{
|
|
||||||
version = expansion.getVersion(expansion.getLatestVersion());
|
version = expansion.getVersion(expansion.getLatestVersion());
|
||||||
if (version == null)
|
if (version == null) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cCould not find latest version for expansion.");
|
"&cCould not find latest version for expansion.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
version = expansion.getVersion(params.get(1));
|
version = expansion.getVersion(params.get(1));
|
||||||
if (version == null)
|
if (version == null) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cCould not find specified version: &f" + params.get(1),
|
"&cCould not find specified version: &f" + params.get(1),
|
||||||
"&7Available versions: &f" + expansion.getAvailableVersions());
|
"&7Available versions: &f" + expansion.getAvailableVersions());
|
||||||
@ -81,41 +73,43 @@ public final class CommandECloudDownload extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
plugin.getCloudExpansionManager().downloadExpansion(expansion, version).whenComplete((file, exception) -> {
|
plugin.getCloudExpansionManager().downloadExpansion(expansion, version)
|
||||||
if (exception != null)
|
.whenComplete((file, exception) -> {
|
||||||
{
|
if (exception != null) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cFailed to download expansion: &f" + exception.getMessage());
|
"&cFailed to download expansion: &f" + exception.getMessage());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&aSuccessfully downloaded expansion &f" + expansion.getName() + " [" + version.getVersion() + "] &ato file: &f" + file.getName(),
|
"&aSuccessfully downloaded expansion &f" + expansion.getName() + " [" + version
|
||||||
|
.getVersion() + "] &ato file: &f" + file.getName(),
|
||||||
"&aMake sure to type &f/papi reload &ato enable your new expansion!");
|
"&aMake sure to type &f/papi reload &ato enable your new expansion!");
|
||||||
|
|
||||||
plugin.getCloudExpansionManager().clean();
|
plugin.getCloudExpansionManager().clean();
|
||||||
plugin.getCloudExpansionManager().fetch(plugin.getPlaceholderAPIConfig().cloudAllowUnverifiedExpansions());
|
plugin.getCloudExpansionManager()
|
||||||
|
.fetch(plugin.getPlaceholderAPIConfig().cloudAllowUnverifiedExpansions());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.size() > 2)
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
{
|
if (params.size() > 2) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (params.size() <= 1)
|
if (params.size() <= 1) {
|
||||||
{
|
final Stream<String> names = plugin.getCloudExpansionManager().getCloudExpansions().values()
|
||||||
final Stream<String> names = plugin.getCloudExpansionManager().getCloudExpansions().values().stream().map(CloudExpansion::getName).map(name -> name.replace(' ', '_'));
|
.stream().map(CloudExpansion::getName).map(name -> name.replace(' ', '_'));
|
||||||
suggestByParameter(names, suggestions, params.isEmpty() ? null : params.get(0));
|
suggestByParameter(names, suggestions, params.isEmpty() ? null : params.get(0));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final Optional<CloudExpansion> expansion = plugin.getCloudExpansionManager().findCloudExpansionByName(params.get(0));
|
final Optional<CloudExpansion> expansion = plugin.getCloudExpansionManager()
|
||||||
if (!expansion.isPresent())
|
.findCloudExpansionByName(params.get(0));
|
||||||
{
|
if (!expansion.isPresent()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,6 +20,9 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.cloud;
|
package me.clip.placeholderapi.commands.impl.cloud;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.stream.Stream;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
||||||
@ -28,31 +31,25 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandECloudExpansionInfo extends PlaceholderCommand {
|
||||||
import java.util.Optional;
|
|
||||||
import java.util.stream.Stream;
|
|
||||||
|
|
||||||
public final class CommandECloudExpansionInfo extends PlaceholderCommand
|
public CommandECloudExpansionInfo() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandECloudExpansionInfo()
|
|
||||||
{
|
|
||||||
super("info");
|
super("info");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.isEmpty())
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
{
|
if (params.isEmpty()) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cYou must specify the name of the expansion.");
|
"&cYou must specify the name of the expansion.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final CloudExpansion expansion = plugin.getCloudExpansionManager().findCloudExpansionByName(params.get(0)).orElse(null);
|
final CloudExpansion expansion = plugin.getCloudExpansionManager()
|
||||||
if (expansion == null)
|
.findCloudExpansionByName(params.get(0)).orElse(null);
|
||||||
{
|
if (expansion == null) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cThere is no expansion with the name: &f" + params.get(0));
|
"&cThere is no expansion with the name: &f" + params.get(0));
|
||||||
return;
|
return;
|
||||||
@ -71,8 +68,7 @@ public final class CommandECloudExpansionInfo extends PlaceholderCommand
|
|||||||
.append(expansion.isVerified() ? "&a&l✔" : "&c&l❌")
|
.append(expansion.isVerified() ? "&a&l✔" : "&c&l❌")
|
||||||
.append('\n');
|
.append('\n');
|
||||||
|
|
||||||
if (params.size() < 2)
|
if (params.size() < 2) {
|
||||||
{
|
|
||||||
builder.append("&bLatest Version: &f")
|
builder.append("&bLatest Version: &f")
|
||||||
.append(expansion.getLatestVersion())
|
.append(expansion.getLatestVersion())
|
||||||
.append('\n')
|
.append('\n')
|
||||||
@ -83,12 +79,9 @@ public final class CommandECloudExpansionInfo extends PlaceholderCommand
|
|||||||
.append("&bRelease Notes: &f")
|
.append("&bRelease Notes: &f")
|
||||||
.append(expansion.getVersion().getReleaseNotes())
|
.append(expansion.getVersion().getReleaseNotes())
|
||||||
.append('\n');
|
.append('\n');
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
final CloudExpansion.Version version = expansion.getVersion(params.get(1));
|
final CloudExpansion.Version version = expansion.getVersion(params.get(1));
|
||||||
if (version == null)
|
if (version == null) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cCould not find specified version: &f" + params.get(1),
|
"&cCould not find specified version: &f" + params.get(1),
|
||||||
"&aVersions: &f" + expansion.getAvailableVersions());
|
"&aVersions: &f" + expansion.getAvailableVersions());
|
||||||
@ -110,23 +103,23 @@ public final class CommandECloudExpansionInfo extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.size() > 2)
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
{
|
if (params.size() > 2) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (params.size() <= 1)
|
if (params.size() <= 1) {
|
||||||
{
|
final Stream<String> names = plugin.getCloudExpansionManager().getCloudExpansions().values()
|
||||||
final Stream<String> names = plugin.getCloudExpansionManager().getCloudExpansions().values().stream().map(CloudExpansion::getName).map(name -> name.replace(' ', '_'));
|
.stream().map(CloudExpansion::getName).map(name -> name.replace(' ', '_'));
|
||||||
suggestByParameter(names, suggestions, params.isEmpty() ? null : params.get(0));
|
suggestByParameter(names, suggestions, params.isEmpty() ? null : params.get(0));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final Optional<CloudExpansion> expansion = plugin.getCloudExpansionManager().findCloudExpansionByName(params.get(0));
|
final Optional<CloudExpansion> expansion = plugin.getCloudExpansionManager()
|
||||||
if (!expansion.isPresent())
|
.findCloudExpansionByName(params.get(0));
|
||||||
{
|
if (!expansion.isPresent()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,6 +25,19 @@ import com.google.common.collect.ImmutableSet;
|
|||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
import com.google.common.collect.Sets;
|
import com.google.common.collect.Sets;
|
||||||
import com.google.common.primitives.Ints;
|
import com.google.common.primitives.Ints;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
import java.util.function.Function;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
import java.util.stream.IntStream;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.configuration.ExpansionSort;
|
import me.clip.placeholderapi.configuration.ExpansionSort;
|
||||||
@ -39,28 +52,14 @@ import org.bukkit.entity.Player;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.text.SimpleDateFormat;
|
public final class CommandECloudExpansionList extends PlaceholderCommand {
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.LinkedHashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
|
||||||
import java.util.function.Function;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
import java.util.stream.IntStream;
|
|
||||||
|
|
||||||
public final class CommandECloudExpansionList extends PlaceholderCommand
|
|
||||||
{
|
|
||||||
|
|
||||||
private static final int PAGE_SIZE = 10;
|
private static final int PAGE_SIZE = 10;
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final Function<CloudExpansion, Object> EXPANSION_NAME =
|
private static final Function<CloudExpansion, Object> EXPANSION_NAME =
|
||||||
expansion -> (expansion.shouldUpdate() ? "&6" : expansion.hasExpansion() ? "&a" : "&7") + expansion.getName();
|
expansion -> (expansion.shouldUpdate() ? "&6" : expansion.hasExpansion() ? "&a" : "&7")
|
||||||
|
+ expansion.getName();
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final Function<CloudExpansion, Object> EXPANSION_AUTHOR =
|
private static final Function<CloudExpansion, Object> EXPANSION_AUTHOR =
|
||||||
expansion -> "&f" + expansion.getAuthor();
|
expansion -> "&f" + expansion.getAuthor();
|
||||||
@ -72,43 +71,198 @@ public final class CommandECloudExpansionList extends PlaceholderCommand
|
|||||||
expansion -> "&f" + expansion.getLatestVersion();
|
expansion -> "&f" + expansion.getLatestVersion();
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final Function<CloudExpansion, Object> EXPANSION_CURRENT_VERSION =
|
private static final Function<CloudExpansion, Object> EXPANSION_CURRENT_VERSION =
|
||||||
expansion -> "&f" + PlaceholderAPIPlugin.getInstance().getLocalExpansionManager().findExpansionByName(expansion.getName()).map(PlaceholderExpansion::getVersion).orElse("Unknown");
|
expansion -> "&f" + PlaceholderAPIPlugin.getInstance().getLocalExpansionManager()
|
||||||
|
.findExpansionByName(expansion.getName()).map(PlaceholderExpansion::getVersion)
|
||||||
|
.orElse("Unknown");
|
||||||
|
|
||||||
|
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
private static final Set<String> OPTIONS = ImmutableSet.of("all", "installed");
|
private static final Set<String> OPTIONS = ImmutableSet.of("all", "installed");
|
||||||
|
|
||||||
|
|
||||||
public CommandECloudExpansionList()
|
public CommandECloudExpansionList() {
|
||||||
{
|
|
||||||
super("list");
|
super("list");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private static Collection<CloudExpansion> getExpansions(@NotNull final String target,
|
||||||
|
@NotNull final PlaceholderAPIPlugin plugin) {
|
||||||
|
switch (target.toLowerCase()) {
|
||||||
|
case "all":
|
||||||
|
return plugin.getCloudExpansionManager().getCloudExpansions().values();
|
||||||
|
case "installed":
|
||||||
|
return plugin.getCloudExpansionManager().getCloudExpansionsInstalled().values();
|
||||||
|
default:
|
||||||
|
return plugin.getCloudExpansionManager().getCloudExpansionsByAuthor(target).values();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private static List<CloudExpansion> getPage(@NotNull final List<CloudExpansion> expansions,
|
||||||
|
final int page) {
|
||||||
|
final int head = (page * PAGE_SIZE);
|
||||||
|
final int tail = Math.min(expansions.size(), head + PAGE_SIZE);
|
||||||
|
|
||||||
|
if (expansions.size() < head) {
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
|
||||||
|
return expansions.subList(head, tail);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void addExpansionTitle(@NotNull final StringBuilder builder,
|
||||||
|
@NotNull final String target, final int page) {
|
||||||
|
switch (target.toLowerCase()) {
|
||||||
|
case "all":
|
||||||
|
builder.append("&bAll Expansions");
|
||||||
|
break;
|
||||||
|
case "installed":
|
||||||
|
builder.append("&bInstalled Expansions");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
builder.append("&bExpansions by &f")
|
||||||
|
.append(target);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (page == -1) {
|
||||||
|
builder.append('\n');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
builder.append(" &bPage&7: &a")
|
||||||
|
.append(page)
|
||||||
|
.append("&r")
|
||||||
|
.append('\n');
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private static JSONMessage getMessage(@NotNull final List<CloudExpansion> expansions,
|
||||||
|
final int page, final int limit, @NotNull final String target) {
|
||||||
|
final SimpleDateFormat format = PlaceholderAPIPlugin.getDateFormat();
|
||||||
|
|
||||||
|
final StringBuilder tooltip = new StringBuilder();
|
||||||
|
final JSONMessage message = JSONMessage.create();
|
||||||
|
|
||||||
|
for (int index = 0; index < expansions.size(); index++) {
|
||||||
|
final CloudExpansion expansion = expansions.get(index);
|
||||||
|
|
||||||
|
tooltip.append("&bClick to download this expansion!")
|
||||||
|
.append('\n')
|
||||||
|
.append('\n')
|
||||||
|
.append("&bAuthor: &f")
|
||||||
|
.append(expansion.getAuthor())
|
||||||
|
.append('\n')
|
||||||
|
.append("&bVerified: ")
|
||||||
|
.append(expansion.isVerified() ? "&a&l✔&r" : "&c&l❌&r")
|
||||||
|
.append('\n')
|
||||||
|
.append("&bLatest Version: &f")
|
||||||
|
.append(expansion.getLatestVersion())
|
||||||
|
.append('\n')
|
||||||
|
.append("&bReleased: &f")
|
||||||
|
.append(format.format(expansion.getLastUpdate()));
|
||||||
|
|
||||||
|
final String description = expansion.getDescription();
|
||||||
|
if (description != null && !description.isEmpty()) {
|
||||||
|
tooltip.append('\n')
|
||||||
|
.append('\n')
|
||||||
|
.append("&f")
|
||||||
|
.append(description.replace("\r", "").trim());
|
||||||
|
}
|
||||||
|
|
||||||
|
message.then(Msg.color(
|
||||||
|
"&8" + (index + ((page - 1) * PAGE_SIZE) + 1) + ".&r " + (expansion.shouldUpdate() ? "&6"
|
||||||
|
: expansion.hasExpansion() ? "&a" : "&7") + expansion.getName()));
|
||||||
|
|
||||||
|
message.tooltip(Msg.color(tooltip.toString()));
|
||||||
|
message.suggestCommand("/papi ecloud download " + expansion.getName());
|
||||||
|
|
||||||
|
if (index < expansions.size() - 1) {
|
||||||
|
message.newline();
|
||||||
|
}
|
||||||
|
|
||||||
|
tooltip.setLength(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (limit > 1) {
|
||||||
|
message.newline();
|
||||||
|
|
||||||
|
message.then("◀")
|
||||||
|
.color(page > 1 ? ChatColor.GRAY : ChatColor.DARK_GRAY);
|
||||||
|
if (page > 1) {
|
||||||
|
message.runCommand("/papi ecloud list " + target + " " + (page - 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
message.then(" " + page + " ").color(ChatColor.GREEN);
|
||||||
|
|
||||||
|
message.then("▶")
|
||||||
|
.color(page < limit ? ChatColor.GRAY : ChatColor.DARK_GRAY);
|
||||||
|
if (page < limit) {
|
||||||
|
message.runCommand("/papi ecloud list " + target + " " + (page + 1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return message;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void addExpansionTable(@NotNull final List<CloudExpansion> expansions,
|
||||||
|
@NotNull final StringBuilder message, final int startIndex,
|
||||||
|
@NotNull final String versionTitle,
|
||||||
|
@NotNull final Function<CloudExpansion, Object> versionFunction) {
|
||||||
|
final Map<String, Function<CloudExpansion, Object>> functions = new LinkedHashMap<>();
|
||||||
|
|
||||||
|
final AtomicInteger counter = new AtomicInteger(startIndex);
|
||||||
|
functions.put("&f", expansion -> "&8" + counter.getAndIncrement() + ".");
|
||||||
|
|
||||||
|
functions.put("&9Name", EXPANSION_NAME);
|
||||||
|
functions.put("&9Author", EXPANSION_AUTHOR);
|
||||||
|
functions.put("&9Verified", EXPANSION_VERIFIED);
|
||||||
|
functions.put(versionTitle, versionFunction);
|
||||||
|
|
||||||
|
final List<List<String>> rows = new ArrayList<>();
|
||||||
|
|
||||||
|
rows.add(0, new ArrayList<>(functions.keySet()));
|
||||||
|
|
||||||
|
for (final CloudExpansion expansion : expansions) {
|
||||||
|
rows.add(functions.values().stream().map(function -> function.apply(expansion))
|
||||||
|
.map(Objects::toString).collect(Collectors.toList()));
|
||||||
|
}
|
||||||
|
|
||||||
|
final List<String> table = Format.tablify(Format.Align.LEFT, rows)
|
||||||
|
.orElse(Collections.emptyList());
|
||||||
|
if (table.isEmpty()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
table.add(1, "&8" + Strings.repeat("-", table.get(0).length() - (rows.get(0).size() * 2)));
|
||||||
|
|
||||||
|
message.append(String.join("\n", table));
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.isEmpty())
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
{
|
if (params.isEmpty()) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cYou must specify an option. [all, {author}, installed]");
|
"&cYou must specify an option. [all, {author}, installed]");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
final boolean installed = params.get(0).equalsIgnoreCase("installed");
|
final boolean installed = params.get(0).equalsIgnoreCase("installed");
|
||||||
final List<CloudExpansion> expansions = Lists.newArrayList(getExpansions(params.get(0), plugin));
|
final List<CloudExpansion> expansions = Lists
|
||||||
|
.newArrayList(getExpansions(params.get(0), plugin));
|
||||||
|
|
||||||
if (expansions.isEmpty())
|
if (expansions.isEmpty()) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cNo expansions available to list.");
|
"&cNo expansions available to list.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
expansions.sort(plugin.getPlaceholderAPIConfig().getExpansionSort().orElse(ExpansionSort.LATEST));
|
expansions
|
||||||
|
.sort(plugin.getPlaceholderAPIConfig().getExpansionSort().orElse(ExpansionSort.LATEST));
|
||||||
|
|
||||||
if (!(sender instanceof Player) && params.size() < 2)
|
if (!(sender instanceof Player) && params.size() < 2) {
|
||||||
{
|
|
||||||
final StringBuilder builder = new StringBuilder();
|
final StringBuilder builder = new StringBuilder();
|
||||||
|
|
||||||
addExpansionTitle(builder, params.get(0), -1);
|
addExpansionTitle(builder, params.get(0), -1);
|
||||||
@ -124,16 +278,12 @@ public final class CommandECloudExpansionList extends PlaceholderCommand
|
|||||||
|
|
||||||
final int page;
|
final int page;
|
||||||
|
|
||||||
if (params.size() < 2)
|
if (params.size() < 2) {
|
||||||
{
|
|
||||||
page = 1;
|
page = 1;
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
//noinspection UnstableApiUsage
|
//noinspection UnstableApiUsage
|
||||||
final Integer parsed = Ints.tryParse(params.get(1));
|
final Integer parsed = Ints.tryParse(params.get(1));
|
||||||
if (parsed == null)
|
if (parsed == null) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cPage number must be an integer.");
|
"&cPage number must be an integer.");
|
||||||
return;
|
return;
|
||||||
@ -141,8 +291,7 @@ public final class CommandECloudExpansionList extends PlaceholderCommand
|
|||||||
|
|
||||||
final int limit = (int) Math.ceil((double) expansions.size() / PAGE_SIZE);
|
final int limit = (int) Math.ceil((double) expansions.size() / PAGE_SIZE);
|
||||||
|
|
||||||
if (parsed < 1 || parsed > limit)
|
if (parsed < 1 || parsed > limit) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cPage number must be in the range &8[&a1&7..&a" + limit + "&8]");
|
"&cPage number must be in the range &8[&a1&7..&a" + limit + "&8]");
|
||||||
return;
|
return;
|
||||||
@ -156,8 +305,7 @@ public final class CommandECloudExpansionList extends PlaceholderCommand
|
|||||||
|
|
||||||
addExpansionTitle(builder, params.get(0), page);
|
addExpansionTitle(builder, params.get(0), page);
|
||||||
|
|
||||||
if (!(sender instanceof Player))
|
if (!(sender instanceof Player)) {
|
||||||
{
|
|
||||||
addExpansionTable(values,
|
addExpansionTable(values,
|
||||||
builder,
|
builder,
|
||||||
((page - 1) * PAGE_SIZE) + 1,
|
((page - 1) * PAGE_SIZE) + 1,
|
||||||
@ -178,183 +326,23 @@ public final class CommandECloudExpansionList extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.size() > 2)
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
{
|
if (params.size() > 2) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (params.size() <= 1)
|
if (params.size() <= 1) {
|
||||||
{
|
suggestByParameter(
|
||||||
suggestByParameter(Sets.union(OPTIONS, plugin.getCloudExpansionManager().getCloudExpansionAuthors()).stream(), suggestions, params.isEmpty() ? null : params.get(0));
|
Sets.union(OPTIONS, plugin.getCloudExpansionManager().getCloudExpansionAuthors())
|
||||||
|
.stream(), suggestions, params.isEmpty() ? null : params.get(0));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
suggestByParameter(IntStream.rangeClosed(1, (int) Math.ceil((double) getExpansions(params.get(0), plugin).size() / PAGE_SIZE)).mapToObj(Objects::toString), suggestions, params.get(1));
|
suggestByParameter(IntStream.rangeClosed(1,
|
||||||
}
|
(int) Math.ceil((double) getExpansions(params.get(0), plugin).size() / PAGE_SIZE))
|
||||||
|
.mapToObj(Objects::toString), suggestions, params.get(1));
|
||||||
|
|
||||||
@NotNull
|
|
||||||
private static Collection<CloudExpansion> getExpansions(@NotNull final String target, @NotNull final PlaceholderAPIPlugin plugin)
|
|
||||||
{
|
|
||||||
switch (target.toLowerCase())
|
|
||||||
{
|
|
||||||
case "all":
|
|
||||||
return plugin.getCloudExpansionManager().getCloudExpansions().values();
|
|
||||||
case "installed":
|
|
||||||
return plugin.getCloudExpansionManager().getCloudExpansionsInstalled().values();
|
|
||||||
default:
|
|
||||||
return plugin.getCloudExpansionManager().getCloudExpansionsByAuthor(target).values();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
private static List<CloudExpansion> getPage(@NotNull final List<CloudExpansion> expansions, final int page)
|
|
||||||
{
|
|
||||||
final int head = (page * PAGE_SIZE);
|
|
||||||
final int tail = Math.min(expansions.size(), head + PAGE_SIZE);
|
|
||||||
|
|
||||||
if (expansions.size() < head)
|
|
||||||
{
|
|
||||||
return Collections.emptyList();
|
|
||||||
}
|
|
||||||
|
|
||||||
return expansions.subList(head, tail);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void addExpansionTitle(@NotNull final StringBuilder builder, @NotNull final String target, final int page)
|
|
||||||
{
|
|
||||||
switch (target.toLowerCase())
|
|
||||||
{
|
|
||||||
case "all":
|
|
||||||
builder.append("&bAll Expansions");
|
|
||||||
break;
|
|
||||||
case "installed":
|
|
||||||
builder.append("&bInstalled Expansions");
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
builder.append("&bExpansions by &f")
|
|
||||||
.append(target);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (page == -1)
|
|
||||||
{
|
|
||||||
builder.append('\n');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
builder.append(" &bPage&7: &a")
|
|
||||||
.append(page)
|
|
||||||
.append("&r")
|
|
||||||
.append('\n');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
private static JSONMessage getMessage(@NotNull final List<CloudExpansion> expansions, final int page, final int limit, @NotNull final String target)
|
|
||||||
{
|
|
||||||
final SimpleDateFormat format = PlaceholderAPIPlugin.getDateFormat();
|
|
||||||
|
|
||||||
final StringBuilder tooltip = new StringBuilder();
|
|
||||||
final JSONMessage message = JSONMessage.create();
|
|
||||||
|
|
||||||
for (int index = 0; index < expansions.size(); index++)
|
|
||||||
{
|
|
||||||
final CloudExpansion expansion = expansions.get(index);
|
|
||||||
|
|
||||||
tooltip.append("&bClick to download this expansion!")
|
|
||||||
.append('\n')
|
|
||||||
.append('\n')
|
|
||||||
.append("&bAuthor: &f")
|
|
||||||
.append(expansion.getAuthor())
|
|
||||||
.append('\n')
|
|
||||||
.append("&bVerified: ")
|
|
||||||
.append(expansion.isVerified() ? "&a&l✔&r" : "&c&l❌&r")
|
|
||||||
.append('\n')
|
|
||||||
.append("&bLatest Version: &f")
|
|
||||||
.append(expansion.getLatestVersion())
|
|
||||||
.append('\n')
|
|
||||||
.append("&bReleased: &f")
|
|
||||||
.append(format.format(expansion.getLastUpdate()));
|
|
||||||
|
|
||||||
final String description = expansion.getDescription();
|
|
||||||
if (description != null && !description.isEmpty())
|
|
||||||
{
|
|
||||||
tooltip.append('\n')
|
|
||||||
.append('\n')
|
|
||||||
.append("&f")
|
|
||||||
.append(description.replace("\r", "").trim());
|
|
||||||
}
|
|
||||||
|
|
||||||
message.then(Msg.color("&8" + (index + ((page - 1) * PAGE_SIZE) + 1) + ".&r " + (expansion.shouldUpdate() ? "&6" : expansion.hasExpansion() ? "&a" : "&7") + expansion.getName()));
|
|
||||||
|
|
||||||
message.tooltip(Msg.color(tooltip.toString()));
|
|
||||||
message.suggestCommand("/papi ecloud download " + expansion.getName());
|
|
||||||
|
|
||||||
if (index < expansions.size() - 1)
|
|
||||||
{
|
|
||||||
message.newline();
|
|
||||||
}
|
|
||||||
|
|
||||||
tooltip.setLength(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (limit > 1)
|
|
||||||
{
|
|
||||||
message.newline();
|
|
||||||
|
|
||||||
message.then("◀")
|
|
||||||
.color(page > 1 ? ChatColor.GRAY : ChatColor.DARK_GRAY);
|
|
||||||
if (page > 1)
|
|
||||||
{
|
|
||||||
message.runCommand("/papi ecloud list " + target + " " + (page - 1));
|
|
||||||
}
|
|
||||||
|
|
||||||
message.then(" " + page + " ").color(ChatColor.GREEN);
|
|
||||||
|
|
||||||
message.then("▶")
|
|
||||||
.color(page < limit ? ChatColor.GRAY : ChatColor.DARK_GRAY);
|
|
||||||
if (page < limit)
|
|
||||||
{
|
|
||||||
message.runCommand("/papi ecloud list " + target + " " + (page + 1));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return message;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void addExpansionTable(@NotNull final List<CloudExpansion> expansions, @NotNull final StringBuilder message, final int startIndex, @NotNull final String versionTitle, @NotNull final Function<CloudExpansion, Object> versionFunction)
|
|
||||||
{
|
|
||||||
final Map<String, Function<CloudExpansion, Object>> functions = new LinkedHashMap<>();
|
|
||||||
|
|
||||||
final AtomicInteger counter = new AtomicInteger(startIndex);
|
|
||||||
functions.put("&f", expansion -> "&8" + counter.getAndIncrement() + ".");
|
|
||||||
|
|
||||||
functions.put("&9Name", EXPANSION_NAME);
|
|
||||||
functions.put("&9Author", EXPANSION_AUTHOR);
|
|
||||||
functions.put("&9Verified", EXPANSION_VERIFIED);
|
|
||||||
functions.put(versionTitle, versionFunction);
|
|
||||||
|
|
||||||
final List<List<String>> rows = new ArrayList<>();
|
|
||||||
|
|
||||||
rows.add(0, new ArrayList<>(functions.keySet()));
|
|
||||||
|
|
||||||
for (final CloudExpansion expansion : expansions)
|
|
||||||
{
|
|
||||||
rows.add(functions.values().stream().map(function -> function.apply(expansion)).map(Objects::toString).collect(Collectors.toList()));
|
|
||||||
}
|
|
||||||
|
|
||||||
final List<String> table = Format.tablify(Format.Align.LEFT, rows).orElse(Collections.emptyList());
|
|
||||||
if (table.isEmpty())
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.add(1, "&8" + Strings.repeat("-", table.get(0).length() - (rows.get(0).size() * 2)));
|
|
||||||
|
|
||||||
message.append(String.join("\n", table));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -21,6 +21,9 @@
|
|||||||
package me.clip.placeholderapi.commands.impl.cloud;
|
package me.clip.placeholderapi.commands.impl.cloud;
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
import java.util.stream.Stream;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
||||||
@ -29,57 +32,52 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandECloudExpansionPlaceholders extends PlaceholderCommand {
|
||||||
import java.util.stream.Collectors;
|
|
||||||
import java.util.stream.Stream;
|
|
||||||
|
|
||||||
public final class CommandECloudExpansionPlaceholders extends PlaceholderCommand
|
public CommandECloudExpansionPlaceholders() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandECloudExpansionPlaceholders()
|
|
||||||
{
|
|
||||||
super("placeholders");
|
super("placeholders");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.isEmpty())
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
{
|
if (params.isEmpty()) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cYou must specify the name of the expansion.");
|
"&cYou must specify the name of the expansion.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final CloudExpansion expansion = plugin.getCloudExpansionManager().findCloudExpansionByName(params.get(0)).orElse(null);
|
final CloudExpansion expansion = plugin.getCloudExpansionManager()
|
||||||
if (expansion == null)
|
.findCloudExpansionByName(params.get(0)).orElse(null);
|
||||||
{
|
if (expansion == null) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cThere is no expansion with the name: &f" + params.get(0));
|
"&cThere is no expansion with the name: &f" + params.get(0));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<String> placeholders = expansion.getPlaceholders();
|
final List<String> placeholders = expansion.getPlaceholders();
|
||||||
if (placeholders == null || placeholders.isEmpty())
|
if (placeholders == null || placeholders.isEmpty()) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cThe expansion specified does not have placeholders listed.");
|
"&cThe expansion specified does not have placeholders listed.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<List<String>> partitions = Lists.partition(placeholders.stream().sorted().collect(Collectors.toList()), 10);
|
final List<List<String>> partitions = Lists
|
||||||
|
.partition(placeholders.stream().sorted().collect(Collectors.toList()), 10);
|
||||||
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&6" + placeholders.size() + "&7 placeholders: &a",
|
"&6" + placeholders.size() + "&7 placeholders: &a",
|
||||||
partitions.stream().map(partition -> String.join(", ", partition)).collect(Collectors.joining("\n")));
|
partitions.stream().map(partition -> String.join(", ", partition))
|
||||||
|
.collect(Collectors.joining("\n")));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.size() > 1)
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
{
|
if (params.size() > 1) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.cloud;
|
package me.clip.placeholderapi.commands.impl.cloud;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.util.Msg;
|
import me.clip.placeholderapi.util.Msg;
|
||||||
@ -27,21 +28,19 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandECloudRefresh extends PlaceholderCommand {
|
||||||
|
|
||||||
public final class CommandECloudRefresh extends PlaceholderCommand
|
public CommandECloudRefresh() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandECloudRefresh()
|
|
||||||
{
|
|
||||||
super("refresh");
|
super("refresh");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
plugin.getCloudExpansionManager().clean();
|
plugin.getCloudExpansionManager().clean();
|
||||||
plugin.getCloudExpansionManager().fetch(plugin.getPlaceholderAPIConfig().cloudAllowUnverifiedExpansions());
|
plugin.getCloudExpansionManager()
|
||||||
|
.fetch(plugin.getPlaceholderAPIConfig().cloudAllowUnverifiedExpansions());
|
||||||
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&aThe eCloud manager has been refreshed!");
|
"&aThe eCloud manager has been refreshed!");
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.cloud;
|
package me.clip.placeholderapi.commands.impl.cloud;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.expansion.manager.CloudExpansionManager;
|
import me.clip.placeholderapi.expansion.manager.CloudExpansionManager;
|
||||||
@ -28,19 +29,16 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandECloudStatus extends PlaceholderCommand {
|
||||||
|
|
||||||
public final class CommandECloudStatus extends PlaceholderCommand
|
public CommandECloudStatus() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandECloudStatus()
|
|
||||||
{
|
|
||||||
super("status");
|
super("status");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
final CloudExpansionManager manager = plugin.getCloudExpansionManager();
|
final CloudExpansionManager manager = plugin.getCloudExpansionManager();
|
||||||
|
|
||||||
final int updateCount = manager.getCloudUpdateCount();
|
final int updateCount = manager.getCloudUpdateCount();
|
||||||
@ -49,15 +47,18 @@ public final class CommandECloudStatus extends PlaceholderCommand
|
|||||||
|
|
||||||
final StringBuilder builder = new StringBuilder();
|
final StringBuilder builder = new StringBuilder();
|
||||||
|
|
||||||
builder.append("&bThere are &a").append(expansionCount).append("&b expansions available on the eCloud.").append('\n');
|
builder.append("&bThere are &a").append(expansionCount)
|
||||||
builder.append("&7A total of &f").append(authorCount).append("&7 authors have contributed to the eCloud.").append('\n');
|
.append("&b expansions available on the eCloud.").append('\n');
|
||||||
|
builder.append("&7A total of &f").append(authorCount)
|
||||||
|
.append("&7 authors have contributed to the eCloud.").append('\n');
|
||||||
|
|
||||||
if (updateCount > 0)
|
if (updateCount > 0) {
|
||||||
{
|
builder.append("&eYou have &f").append(updateCount)
|
||||||
builder.append("&eYou have &f").append(updateCount).append(updateCount > 1 ? "&e expansions" : "&e expansion").append("installed that ").append(updateCount > 1 ? "have an" : "has an").append(" update available.");
|
.append(updateCount > 1 ? "&e expansions" : "&e expansion").append("installed that ")
|
||||||
|
.append(updateCount > 1 ? "have an" : "has an").append(" update available.");
|
||||||
}
|
}
|
||||||
|
|
||||||
Msg.msg(sender,builder.toString());
|
Msg.msg(sender, builder.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.cloud;
|
package me.clip.placeholderapi.commands.impl.cloud;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.util.Msg;
|
import me.clip.placeholderapi.util.Msg;
|
||||||
@ -27,24 +28,20 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandECloudToggle extends PlaceholderCommand {
|
||||||
|
|
||||||
public final class CommandECloudToggle extends PlaceholderCommand
|
public CommandECloudToggle() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandECloudToggle()
|
|
||||||
{
|
|
||||||
super("toggle", "enable", "disable");
|
super("toggle", "enable", "disable");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
final boolean desiredState;
|
final boolean desiredState;
|
||||||
final boolean currentState = plugin.getPlaceholderAPIConfig().isCloudEnabled();
|
final boolean currentState = plugin.getPlaceholderAPIConfig().isCloudEnabled();
|
||||||
|
|
||||||
switch (alias.toLowerCase())
|
switch (alias.toLowerCase()) {
|
||||||
{
|
|
||||||
case "enable":
|
case "enable":
|
||||||
desiredState = true;
|
desiredState = true;
|
||||||
break;
|
break;
|
||||||
@ -56,20 +53,16 @@ public final class CommandECloudToggle extends PlaceholderCommand
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (desiredState == currentState)
|
if (desiredState == currentState) {
|
||||||
{
|
|
||||||
Msg.msg(sender, "&7The eCloud Manager is already " + (desiredState ? "enabled" : "disabled"));
|
Msg.msg(sender, "&7The eCloud Manager is already " + (desiredState ? "enabled" : "disabled"));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
plugin.getPlaceholderAPIConfig().setCloudEnabled(desiredState);
|
plugin.getPlaceholderAPIConfig().setCloudEnabled(desiredState);
|
||||||
|
|
||||||
if (desiredState)
|
if (desiredState) {
|
||||||
{
|
|
||||||
plugin.getCloudExpansionManager().load();
|
plugin.getCloudExpansionManager().load();
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
plugin.getCloudExpansionManager().kill();
|
plugin.getCloudExpansionManager().kill();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,6 +21,12 @@
|
|||||||
package me.clip.placeholderapi.commands.impl.cloud;
|
package me.clip.placeholderapi.commands.impl.cloud;
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||||
@ -32,30 +38,29 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.Optional;
|
|
||||||
import java.util.concurrent.CompletableFuture;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* please don't flame me for this code, I will fix this shit later.
|
* please don't flame me for this code, I will fix this shit later.
|
||||||
*/
|
*/
|
||||||
public final class CommandECloudUpdate extends PlaceholderCommand
|
public final class CommandECloudUpdate extends PlaceholderCommand {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandECloudUpdate()
|
public CommandECloudUpdate() {
|
||||||
{
|
|
||||||
super("update");
|
super("update");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static CompletableFuture<List<@Nullable Class<? extends PlaceholderExpansion>>> downloadAndDiscover(
|
||||||
|
@NotNull final List<CloudExpansion> expansions, @NotNull final PlaceholderAPIPlugin plugin) {
|
||||||
|
return expansions.stream()
|
||||||
|
.map(expansion -> plugin.getCloudExpansionManager()
|
||||||
|
.downloadExpansion(expansion, expansion.getVersion()))
|
||||||
|
.map(future -> future.thenCompose(plugin.getLocalExpansionManager()::findExpansionInFile))
|
||||||
|
.collect(Futures.collector());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.isEmpty())
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
{
|
if (params.isEmpty()) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cYou must define 'all' or the name of an expansion to update.");
|
"&cYou must define 'all' or the name of an expansion to update.");
|
||||||
return;
|
return;
|
||||||
@ -65,32 +70,29 @@ public final class CommandECloudUpdate extends PlaceholderCommand
|
|||||||
final List<CloudExpansion> expansions = new ArrayList<>();
|
final List<CloudExpansion> expansions = new ArrayList<>();
|
||||||
|
|
||||||
// gather target expansions
|
// gather target expansions
|
||||||
if (multiple)
|
if (multiple) {
|
||||||
{
|
|
||||||
expansions.addAll(plugin.getCloudExpansionManager().getCloudExpansionsInstalled().values());
|
expansions.addAll(plugin.getCloudExpansionManager().getCloudExpansionsInstalled().values());
|
||||||
}
|
} else {
|
||||||
else
|
plugin.getCloudExpansionManager().findCloudExpansionByName(params.get(0))
|
||||||
{
|
.ifPresent(expansions::add);
|
||||||
plugin.getCloudExpansionManager().findCloudExpansionByName(params.get(0)).ifPresent(expansions::add);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// remove the ones that are the latest version
|
// remove the ones that are the latest version
|
||||||
expansions.removeIf(expansion -> !expansion.shouldUpdate());
|
expansions.removeIf(expansion -> !expansion.shouldUpdate());
|
||||||
|
|
||||||
if (expansions.isEmpty())
|
if (expansions.isEmpty()) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cNo updates available for " + (!multiple ? "this expansion." : "your active expansions."));
|
"&cNo updates available for " + (!multiple ? "this expansion."
|
||||||
|
: "your active expansions."));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&aUpdating expansions: " + expansions.stream().map(CloudExpansion::getName).collect(Collectors.joining("&7, &6", "&8[&6", "&8]&r")));
|
"&aUpdating expansions: " + expansions.stream().map(CloudExpansion::getName)
|
||||||
|
.collect(Collectors.joining("&7, &6", "&8[&6", "&8]&r")));
|
||||||
|
|
||||||
Futures.onMainThread(plugin, downloadAndDiscover(expansions, plugin), (classes, exception) -> {
|
Futures.onMainThread(plugin, downloadAndDiscover(expansions, plugin), (classes, exception) -> {
|
||||||
if (exception != null)
|
if (exception != null) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cFailed to update expansions: &e" + exception.getMessage());
|
"&cFailed to update expansions: &e" + exception.getMessage());
|
||||||
return;
|
return;
|
||||||
@ -99,7 +101,6 @@ public final class CommandECloudUpdate extends PlaceholderCommand
|
|||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&aSuccessfully downloaded updates, registering new versions.");
|
"&aSuccessfully downloaded updates, registering new versions.");
|
||||||
|
|
||||||
|
|
||||||
final String message = classes.stream()
|
final String message = classes.stream()
|
||||||
.filter(Objects::nonNull)
|
.filter(Objects::nonNull)
|
||||||
.map(plugin.getLocalExpansionManager()::register)
|
.map(plugin.getLocalExpansionManager()::register)
|
||||||
@ -115,31 +116,25 @@ public final class CommandECloudUpdate extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.size() > 1)
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
{
|
if (params.size() > 1) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<CloudExpansion> installed = Lists.newArrayList(plugin.getCloudExpansionManager().getCloudExpansionsInstalled().values());
|
final List<CloudExpansion> installed = Lists
|
||||||
|
.newArrayList(plugin.getCloudExpansionManager().getCloudExpansionsInstalled().values());
|
||||||
installed.removeIf(expansion -> !expansion.shouldUpdate());
|
installed.removeIf(expansion -> !expansion.shouldUpdate());
|
||||||
|
|
||||||
if (!installed.isEmpty() && (params.isEmpty() || "all".startsWith(params.get(0).toLowerCase())))
|
if (!installed.isEmpty() && (params.isEmpty() || "all"
|
||||||
{
|
.startsWith(params.get(0).toLowerCase()))) {
|
||||||
suggestions.add("all");
|
suggestions.add("all");
|
||||||
}
|
}
|
||||||
|
|
||||||
suggestByParameter(installed.stream().map(CloudExpansion::getName).map(name -> name.replace(" ", "_")), suggestions, params.isEmpty() ? null : params.get(0));
|
suggestByParameter(
|
||||||
}
|
installed.stream().map(CloudExpansion::getName).map(name -> name.replace(" ", "_")),
|
||||||
|
suggestions, params.isEmpty() ? null : params.get(0));
|
||||||
|
|
||||||
private static CompletableFuture<List<@Nullable Class<? extends PlaceholderExpansion>>> downloadAndDiscover(@NotNull final List<CloudExpansion> expansions, @NotNull final PlaceholderAPIPlugin plugin)
|
|
||||||
{
|
|
||||||
return expansions.stream()
|
|
||||||
.map(expansion -> plugin.getCloudExpansionManager().downloadExpansion(expansion, expansion.getVersion()))
|
|
||||||
.map(future -> future.thenCompose(plugin.getLocalExpansionManager()::findExpansionInFile))
|
|
||||||
.collect(Futures.collector());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -22,15 +22,6 @@ package me.clip.placeholderapi.commands.impl.local;
|
|||||||
|
|
||||||
import com.google.common.io.CharStreams;
|
import com.google.common.io.CharStreams;
|
||||||
import com.google.gson.JsonParser;
|
import com.google.gson.JsonParser;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
|
||||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
|
||||||
import me.clip.placeholderapi.util.Msg;
|
|
||||||
import org.bukkit.command.CommandSender;
|
|
||||||
import org.bukkit.plugin.Plugin;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
@ -50,30 +41,37 @@ import java.util.concurrent.CompletableFuture;
|
|||||||
import java.util.concurrent.CompletionException;
|
import java.util.concurrent.CompletionException;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||||
|
import me.clip.placeholderapi.util.Msg;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.plugin.Plugin;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
public final class CommandDump extends PlaceholderCommand
|
public final class CommandDump extends PlaceholderCommand {
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final String URL = "https://paste.helpch.at/";
|
private static final String URL = "https://paste.helpch.at/";
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final DateTimeFormatter DATE_FORMAT = DateTimeFormatter.ofLocalizedDateTime(FormatStyle.LONG)
|
private static final DateTimeFormatter DATE_FORMAT = DateTimeFormatter
|
||||||
|
.ofLocalizedDateTime(FormatStyle.LONG)
|
||||||
.withLocale(Locale.US)
|
.withLocale(Locale.US)
|
||||||
.withZone(ZoneId.of("UTC"));
|
.withZone(ZoneId.of("UTC"));
|
||||||
|
|
||||||
|
|
||||||
public CommandDump()
|
public CommandDump() {
|
||||||
{
|
|
||||||
super("dump");
|
super("dump");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
postDump(makeDump(plugin)).whenComplete((key, exception) -> {
|
postDump(makeDump(plugin)).whenComplete((key, exception) -> {
|
||||||
if (exception != null)
|
if (exception != null) {
|
||||||
{
|
|
||||||
plugin.getLogger().log(Level.WARNING, "failed to post dump details", exception);
|
plugin.getLogger().log(Level.WARNING, "failed to post dump details", exception);
|
||||||
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
@ -87,40 +85,35 @@ public final class CommandDump extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private CompletableFuture<String> postDump(@NotNull final String dump)
|
private CompletableFuture<String> postDump(@NotNull final String dump) {
|
||||||
{
|
|
||||||
return CompletableFuture.supplyAsync(() -> {
|
return CompletableFuture.supplyAsync(() -> {
|
||||||
try
|
try {
|
||||||
{
|
final HttpURLConnection connection = ((HttpURLConnection) new URL(URL + "documents")
|
||||||
final HttpURLConnection connection = ((HttpURLConnection) new URL(URL + "documents").openConnection());
|
.openConnection());
|
||||||
connection.setRequestMethod("POST");
|
connection.setRequestMethod("POST");
|
||||||
connection.setRequestProperty("Content-Type", "text/plain; charset=utf-8");
|
connection.setRequestProperty("Content-Type", "text/plain; charset=utf-8");
|
||||||
connection.setDoOutput(true);
|
connection.setDoOutput(true);
|
||||||
|
|
||||||
connection.connect();
|
connection.connect();
|
||||||
|
|
||||||
try (final OutputStream stream = connection.getOutputStream())
|
try (final OutputStream stream = connection.getOutputStream()) {
|
||||||
{
|
|
||||||
stream.write(dump.getBytes(StandardCharsets.UTF_8));
|
stream.write(dump.getBytes(StandardCharsets.UTF_8));
|
||||||
}
|
}
|
||||||
|
|
||||||
try (final InputStream stream = connection.getInputStream())
|
try (final InputStream stream = connection.getInputStream()) {
|
||||||
{
|
|
||||||
//noinspection UnstableApiUsage
|
//noinspection UnstableApiUsage
|
||||||
final String json = CharStreams.toString(new InputStreamReader(stream, StandardCharsets.UTF_8));
|
final String json = CharStreams
|
||||||
|
.toString(new InputStreamReader(stream, StandardCharsets.UTF_8));
|
||||||
return JsonParser.parseString(json).getAsJsonObject().get("key").getAsString();
|
return JsonParser.parseString(json).getAsJsonObject().get("key").getAsString();
|
||||||
}
|
}
|
||||||
}
|
} catch (final IOException ex) {
|
||||||
catch (final IOException ex)
|
|
||||||
{
|
|
||||||
throw new CompletionException(ex);
|
throw new CompletionException(ex);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private String makeDump(@NotNull final PlaceholderAPIPlugin plugin)
|
private String makeDump(@NotNull final PlaceholderAPIPlugin plugin) {
|
||||||
{
|
|
||||||
final StringBuilder builder = new StringBuilder();
|
final StringBuilder builder = new StringBuilder();
|
||||||
|
|
||||||
builder.append("Generated: ")
|
builder.append("Generated: ")
|
||||||
@ -143,7 +136,8 @@ public final class CommandDump extends PlaceholderCommand
|
|||||||
|
|
||||||
int size = 0;
|
int size = 0;
|
||||||
|
|
||||||
for(final String name : expansions.stream().map(PlaceholderExpansion::getIdentifier).collect(Collectors.toList())){
|
for (final String name : expansions.stream().map(PlaceholderExpansion::getIdentifier)
|
||||||
|
.collect(Collectors.toList())) {
|
||||||
if (name.length() > size) {
|
if (name.length() > size) {
|
||||||
size = name.length();
|
size = name.length();
|
||||||
}
|
}
|
||||||
@ -169,8 +163,7 @@ public final class CommandDump extends PlaceholderCommand
|
|||||||
.getExpansionsFolder()
|
.getExpansionsFolder()
|
||||||
.list((dir, name) -> name.toLowerCase().endsWith(".jar"));
|
.list((dir, name) -> name.toLowerCase().endsWith(".jar"));
|
||||||
|
|
||||||
for (final String jar : jars)
|
for (final String jar : jars) {
|
||||||
{
|
|
||||||
builder.append(" ")
|
builder.append(" ")
|
||||||
.append(jar)
|
.append(jar)
|
||||||
.append('\n');
|
.append('\n');
|
||||||
@ -178,7 +171,6 @@ public final class CommandDump extends PlaceholderCommand
|
|||||||
|
|
||||||
builder.append('\n');
|
builder.append('\n');
|
||||||
|
|
||||||
|
|
||||||
builder.append("Server Info: ")
|
builder.append("Server Info: ")
|
||||||
.append(plugin.getServer().getBukkitVersion())
|
.append(plugin.getServer().getBukkitVersion())
|
||||||
.append('/')
|
.append('/')
|
||||||
@ -192,14 +184,14 @@ public final class CommandDump extends PlaceholderCommand
|
|||||||
.sorted(Comparator.comparing(Plugin::getName))
|
.sorted(Comparator.comparing(Plugin::getName))
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
|
|
||||||
for (final String pluginName : plugins.stream().map(Plugin::getName).collect(Collectors.toList())) {
|
for (final String pluginName : plugins.stream().map(Plugin::getName)
|
||||||
|
.collect(Collectors.toList())) {
|
||||||
if (pluginName.length() > size) {
|
if (pluginName.length() > size) {
|
||||||
size = pluginName.length();
|
size = pluginName.length();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (final Plugin other : plugins)
|
for (final Plugin other : plugins) {
|
||||||
{
|
|
||||||
builder.append(" ")
|
builder.append(" ")
|
||||||
.append(String.format("%-" + size + "s", other.getName()))
|
.append(String.format("%-" + size + "s", other.getName()))
|
||||||
.append(" [Version: ")
|
.append(" [Version: ")
|
||||||
|
@ -20,6 +20,11 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.local;
|
package me.clip.placeholderapi.commands.impl.local;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.logging.Level;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||||
@ -30,62 +35,49 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.io.File;
|
public final class CommandExpansionRegister extends PlaceholderCommand {
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Optional;
|
|
||||||
import java.util.logging.Level;
|
|
||||||
|
|
||||||
public final class CommandExpansionRegister extends PlaceholderCommand
|
public CommandExpansionRegister() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandExpansionRegister()
|
|
||||||
{
|
|
||||||
super("register");
|
super("register");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.size() < 1)
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
{
|
if (params.size() < 1) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cYou must specify the name of an expansion file.");
|
"&cYou must specify the name of an expansion file.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
final LocalExpansionManager manager = plugin.getLocalExpansionManager();
|
final LocalExpansionManager manager = plugin.getLocalExpansionManager();
|
||||||
|
|
||||||
final File file = new File(manager.getExpansionsFolder(), params.get(0));
|
final File file = new File(manager.getExpansionsFolder(), params.get(0));
|
||||||
if (!file.exists())
|
if (!file.exists()) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cThe file &f" + file.getName() + "&c doesn't exist!");
|
"&cThe file &f" + file.getName() + "&c doesn't exist!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Futures.onMainThread(plugin, manager.findExpansionInFile(file), (clazz, exception) -> {
|
Futures.onMainThread(plugin, manager.findExpansionInFile(file), (clazz, exception) -> {
|
||||||
if (exception != null)
|
if (exception != null) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cFailed to find expansion in file: &f" + file);
|
"&cFailed to find expansion in file: &f" + file);
|
||||||
|
|
||||||
plugin.getLogger().log(Level.WARNING, "failed to find expansion in file: " + file, exception);
|
plugin.getLogger()
|
||||||
|
.log(Level.WARNING, "failed to find expansion in file: " + file, exception);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (clazz == null)
|
if (clazz == null) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cNo expansion class found in file: &f" + file);
|
"&cNo expansion class found in file: &f" + file);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
final Optional<PlaceholderExpansion> expansion = manager.register(clazz);
|
final Optional<PlaceholderExpansion> expansion = manager.register(clazz);
|
||||||
if (!expansion.isPresent())
|
if (!expansion.isPresent()) {
|
||||||
{
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cFailed to register expansion from &f" + params.get(0));
|
"&cFailed to register expansion from &f" + params.get(0));
|
||||||
return;
|
return;
|
||||||
@ -98,20 +90,21 @@ public final class CommandExpansionRegister extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.size() > 1)
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
{
|
if (params.size() > 1) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final String[] fileNames = plugin.getLocalExpansionManager().getExpansionsFolder().list((dir, name) -> name.endsWith(".jar"));
|
final String[] fileNames = plugin.getLocalExpansionManager().getExpansionsFolder()
|
||||||
if (fileNames == null || fileNames.length == 0)
|
.list((dir, name) -> name.endsWith(".jar"));
|
||||||
{
|
if (fileNames == null || fileNames.length == 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
suggestByParameter(Arrays.stream(fileNames), suggestions, params.isEmpty() ? null : params.get(0));
|
suggestByParameter(Arrays.stream(fileNames), suggestions,
|
||||||
|
params.isEmpty() ? null : params.get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,8 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.local;
|
package me.clip.placeholderapi.commands.impl.local;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
import me.clip.placeholderapi.PlaceholderAPI;
|
import me.clip.placeholderapi.PlaceholderAPI;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
@ -29,36 +31,30 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandExpansionUnregister extends PlaceholderCommand {
|
||||||
import java.util.Optional;
|
|
||||||
|
|
||||||
public final class CommandExpansionUnregister extends PlaceholderCommand
|
public CommandExpansionUnregister() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandExpansionUnregister()
|
|
||||||
{
|
|
||||||
super("unregister");
|
super("unregister");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.isEmpty())
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
{
|
if (params.isEmpty()) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cYou must specify the name of the expansion.");
|
"&cYou must specify the name of the expansion.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final Optional<PlaceholderExpansion> expansion = plugin.getLocalExpansionManager().findExpansionByName(params.get(0));
|
final Optional<PlaceholderExpansion> expansion = plugin.getLocalExpansionManager()
|
||||||
if (!expansion.isPresent())
|
.findExpansionByName(params.get(0));
|
||||||
{
|
if (!expansion.isPresent()) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cThere is no expansion loaded with the identifier: &f" + params.get(0));
|
"&cThere is no expansion loaded with the identifier: &f" + params.get(0));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
final String message = !expansion.get().unregister() ?
|
final String message = !expansion.get().unregister() ?
|
||||||
"&cFailed to unregister expansion: &f" :
|
"&cFailed to unregister expansion: &f" :
|
||||||
"&aSuccessfully unregistered expansion: &f";
|
"&aSuccessfully unregistered expansion: &f";
|
||||||
@ -67,14 +63,15 @@ public final class CommandExpansionUnregister extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.size() > 1)
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
{
|
if (params.size() > 1) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
suggestByParameter(PlaceholderAPI.getRegisteredIdentifiers().stream(), suggestions, params.isEmpty() ? null : params.get(0));
|
suggestByParameter(PlaceholderAPI.getRegisteredIdentifiers().stream(), suggestions,
|
||||||
|
params.isEmpty() ? null : params.get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.local;
|
package me.clip.placeholderapi.commands.impl.local;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.util.Msg;
|
import me.clip.placeholderapi.util.Msg;
|
||||||
@ -28,20 +29,17 @@ import org.bukkit.plugin.PluginDescriptionFile;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandHelp extends PlaceholderCommand {
|
||||||
|
|
||||||
public final class CommandHelp extends PlaceholderCommand
|
public CommandHelp() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandHelp()
|
|
||||||
{
|
|
||||||
super("help");
|
super("help");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
final PluginDescriptionFile description = plugin.getDescription();
|
final PluginDescriptionFile description = plugin.getDescription();
|
||||||
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.local;
|
package me.clip.placeholderapi.commands.impl.local;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
import me.clip.placeholderapi.PlaceholderAPI;
|
import me.clip.placeholderapi.PlaceholderAPI;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
@ -29,29 +30,25 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandInfo extends PlaceholderCommand {
|
||||||
|
|
||||||
public final class CommandInfo extends PlaceholderCommand
|
public CommandInfo() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandInfo()
|
|
||||||
{
|
|
||||||
super("info");
|
super("info");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.isEmpty())
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
{
|
if (params.isEmpty()) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cYou must specify the name of the expansion.");
|
"&cYou must specify the name of the expansion.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final PlaceholderExpansion expansion = plugin.getLocalExpansionManager().findExpansionByName(params.get(0)).orElse(null);
|
final PlaceholderExpansion expansion = plugin.getLocalExpansionManager()
|
||||||
if (expansion == null)
|
.findExpansionByName(params.get(0)).orElse(null);
|
||||||
{
|
if (expansion == null) {
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&cThere is no expansion loaded with the identifier: &f" + params.get(0));
|
"&cThere is no expansion loaded with the identifier: &f" + params.get(0));
|
||||||
return;
|
return;
|
||||||
@ -67,37 +64,32 @@ public final class CommandInfo extends PlaceholderCommand
|
|||||||
.append('\n');
|
.append('\n');
|
||||||
|
|
||||||
final String author = expansion.getAuthor();
|
final String author = expansion.getAuthor();
|
||||||
if (author != null)
|
if (author != null) {
|
||||||
{
|
|
||||||
builder.append("&7Author: &r")
|
builder.append("&7Author: &r")
|
||||||
.append(author)
|
.append(author)
|
||||||
.append('\n');
|
.append('\n');
|
||||||
}
|
}
|
||||||
|
|
||||||
final String version = expansion.getVersion();
|
final String version = expansion.getVersion();
|
||||||
if (version != null)
|
if (version != null) {
|
||||||
{
|
|
||||||
builder.append("&7Version: &r")
|
builder.append("&7Version: &r")
|
||||||
.append(version)
|
.append(version)
|
||||||
.append('\n');
|
.append('\n');
|
||||||
}
|
}
|
||||||
|
|
||||||
final String requiredPlugin = expansion.getRequiredPlugin();
|
final String requiredPlugin = expansion.getRequiredPlugin();
|
||||||
if (requiredPlugin != null)
|
if (requiredPlugin != null) {
|
||||||
{
|
|
||||||
builder.append("&7Requires plugin: &r")
|
builder.append("&7Requires plugin: &r")
|
||||||
.append(requiredPlugin)
|
.append(requiredPlugin)
|
||||||
.append('\n');
|
.append('\n');
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<String> placeholders = expansion.getPlaceholders();
|
final List<String> placeholders = expansion.getPlaceholders();
|
||||||
if (placeholders != null && !placeholders.isEmpty())
|
if (placeholders != null && !placeholders.isEmpty()) {
|
||||||
{
|
|
||||||
builder.append("&8&m-- &7Placeholders &8&m--&r")
|
builder.append("&8&m-- &7Placeholders &8&m--&r")
|
||||||
.append('\n');
|
.append('\n');
|
||||||
|
|
||||||
for (final String placeholder : placeholders)
|
for (final String placeholder : placeholders) {
|
||||||
{
|
|
||||||
builder.append(placeholder)
|
builder.append(placeholder)
|
||||||
.append('\n');
|
.append('\n');
|
||||||
}
|
}
|
||||||
@ -107,14 +99,15 @@ public final class CommandInfo extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
if (params.size() > 1)
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
{
|
if (params.size() > 1) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
suggestByParameter(PlaceholderAPI.getRegisteredIdentifiers().stream(), suggestions, params.isEmpty() ? null : params.get(0));
|
suggestByParameter(PlaceholderAPI.getRegisteredIdentifiers().stream(), suggestions,
|
||||||
|
params.isEmpty() ? null : params.get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -21,6 +21,9 @@
|
|||||||
package me.clip.placeholderapi.commands.impl.local;
|
package me.clip.placeholderapi.commands.impl.local;
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
import me.clip.placeholderapi.PlaceholderAPI;
|
import me.clip.placeholderapi.PlaceholderAPI;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
@ -29,34 +32,30 @@ import org.bukkit.command.CommandSender;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandList extends PlaceholderCommand {
|
||||||
import java.util.Set;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
public final class CommandList extends PlaceholderCommand
|
public CommandList() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandList()
|
|
||||||
{
|
|
||||||
super("list");
|
super("list");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
final Set<String> identifiers = PlaceholderAPI.getRegisteredIdentifiers();
|
final Set<String> identifiers = PlaceholderAPI.getRegisteredIdentifiers();
|
||||||
if (identifiers.isEmpty())
|
if (identifiers.isEmpty()) {
|
||||||
{
|
|
||||||
Msg.msg(sender, "&cThere are no placeholder hooks active!");
|
Msg.msg(sender, "&cThere are no placeholder hooks active!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<List<String>> partitions = Lists.partition(identifiers.stream().sorted().collect(Collectors.toList()), 10);
|
final List<List<String>> partitions = Lists
|
||||||
|
.partition(identifiers.stream().sorted().collect(Collectors.toList()), 10);
|
||||||
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
"&7A total of &f" + identifiers.size() + "&7 placeholder hook(s) are active: &a",
|
"&7A total of &f" + identifiers.size() + "&7 placeholder hook(s) are active: &a",
|
||||||
partitions.stream().map(partition -> String.join("&7, &a", partition)).collect(Collectors.joining("\n")));
|
partitions.stream().map(partition -> String.join("&7, &a", partition))
|
||||||
|
.collect(Collectors.joining("\n")));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,10 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.local;
|
package me.clip.placeholderapi.commands.impl.local;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.stream.Stream;
|
||||||
import me.clip.placeholderapi.PlaceholderAPI;
|
import me.clip.placeholderapi.PlaceholderAPI;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
@ -34,27 +38,18 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.Collection;
|
public final class CommandParse extends PlaceholderCommand {
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Optional;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.stream.Stream;
|
|
||||||
|
|
||||||
public final class CommandParse extends PlaceholderCommand
|
public CommandParse() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandParse()
|
|
||||||
{
|
|
||||||
super("parse", "bcparse", "parserel", "cmdparse");
|
super("parse", "bcparse", "parserel", "cmdparse");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
switch (alias.toLowerCase())
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
{
|
switch (alias.toLowerCase()) {
|
||||||
case "parserel":
|
case "parserel":
|
||||||
evaluateParseRelation(sender, params);
|
evaluateParseRelation(sender, params);
|
||||||
break;
|
break;
|
||||||
@ -71,10 +66,10 @@ public final class CommandParse extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void complete(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
public void complete(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
switch (alias.toLowerCase())
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
{
|
switch (alias.toLowerCase()) {
|
||||||
case "parserel":
|
case "parserel":
|
||||||
completeParseRelation(params, suggestions);
|
completeParseRelation(params, suggestions);
|
||||||
break;
|
break;
|
||||||
@ -87,31 +82,28 @@ public final class CommandParse extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void evaluateParseSingular(@NotNull final CommandSender sender, @NotNull @Unmodifiable final List<String> params, final boolean broadcast, final boolean command)
|
private void evaluateParseSingular(@NotNull final CommandSender sender,
|
||||||
{
|
@NotNull @Unmodifiable final List<String> params, final boolean broadcast,
|
||||||
if (params.size() < 2)
|
final boolean command) {
|
||||||
{
|
if (params.size() < 2) {
|
||||||
Msg.msg(sender, "&cYou must supply a target, and a message: &b/papi " + (broadcast ? "bcparse" : "parse") + " &7{target} &a{message}");
|
Msg.msg(sender,
|
||||||
|
"&cYou must supply a target, and a message: &b/papi " + (broadcast ? "bcparse" : "parse")
|
||||||
|
+ " &7{target} &a{message}");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull final OfflinePlayer player;
|
@NotNull final OfflinePlayer player;
|
||||||
|
|
||||||
if ("me".equalsIgnoreCase(params.get(0)))
|
if ("me".equalsIgnoreCase(params.get(0))) {
|
||||||
{
|
if (!(sender instanceof Player)) {
|
||||||
if (!(sender instanceof Player))
|
|
||||||
{
|
|
||||||
Msg.msg(sender, "&cYou must be a player to use &7me&c as a target!");
|
Msg.msg(sender, "&cYou must be a player to use &7me&c as a target!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
player = ((Player) sender);
|
player = ((Player) sender);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
final OfflinePlayer target = resolvePlayer(params.get(0));
|
final OfflinePlayer target = resolvePlayer(params.get(0));
|
||||||
if (target == null)
|
if (target == null) {
|
||||||
{
|
|
||||||
Msg.msg(sender, "&cFailed to find player: &7" + params.get(0));
|
Msg.msg(sender, "&cFailed to find player: &7" + params.get(0));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -119,64 +111,57 @@ public final class CommandParse extends PlaceholderCommand
|
|||||||
player = target;
|
player = target;
|
||||||
}
|
}
|
||||||
|
|
||||||
final String message = PlaceholderAPI.setPlaceholders(player, String.join(" ", params.subList(1, params.size())));
|
final String message = PlaceholderAPI
|
||||||
|
.setPlaceholders(player, String.join(" ", params.subList(1, params.size())));
|
||||||
|
|
||||||
if (command)
|
if (command) {
|
||||||
{
|
|
||||||
Bukkit.dispatchCommand(sender, message);
|
Bukkit.dispatchCommand(sender, message);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (broadcast)
|
if (broadcast) {
|
||||||
{
|
|
||||||
Msg.broadcast(message);
|
Msg.broadcast(message);
|
||||||
}
|
} else {
|
||||||
else
|
if (!(sender instanceof Player)) {
|
||||||
{
|
|
||||||
if (!(sender instanceof Player))
|
|
||||||
{
|
|
||||||
Msg.msg(sender, message);
|
Msg.msg(sender, message);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
((Player) sender).spigot().sendMessage(TextComponent.fromLegacyText(message));
|
((Player) sender).spigot().sendMessage(TextComponent.fromLegacyText(message));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void evaluateParseRelation(@NotNull final CommandSender sender, @NotNull @Unmodifiable final List<String> params)
|
private void evaluateParseRelation(@NotNull final CommandSender sender,
|
||||||
{
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
if (params.size() < 3)
|
if (params.size() < 3) {
|
||||||
{
|
Msg.msg(sender,
|
||||||
Msg.msg(sender, "&cYou must supply two targets, and a message: &b/papi parserel &7{target one} {target two} &a{message}");
|
"&cYou must supply two targets, and a message: &b/papi parserel &7{target one} {target two} &a{message}");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final OfflinePlayer targetOne = resolvePlayer(params.get(0));
|
final OfflinePlayer targetOne = resolvePlayer(params.get(0));
|
||||||
if (targetOne == null || !targetOne.isOnline())
|
if (targetOne == null || !targetOne.isOnline()) {
|
||||||
{
|
|
||||||
Msg.msg(sender, "&cFailed to find player: &f" + params.get(0));
|
Msg.msg(sender, "&cFailed to find player: &f" + params.get(0));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final OfflinePlayer targetTwo = resolvePlayer(params.get(1));
|
final OfflinePlayer targetTwo = resolvePlayer(params.get(1));
|
||||||
if (targetTwo == null || !targetTwo.isOnline())
|
if (targetTwo == null || !targetTwo.isOnline()) {
|
||||||
{
|
|
||||||
Msg.msg(sender, "&cFailed to find player: &f" + params.get(1));
|
Msg.msg(sender, "&cFailed to find player: &f" + params.get(1));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final String message = PlaceholderAPI.setRelationalPlaceholders(((Player) targetOne), ((Player) targetTwo), String.join(" ", params.subList(2, params.size())));
|
final String message = PlaceholderAPI
|
||||||
|
.setRelationalPlaceholders(((Player) targetOne), ((Player) targetTwo),
|
||||||
|
String.join(" ", params.subList(2, params.size())));
|
||||||
Msg.msg(sender, message);
|
Msg.msg(sender, message);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void completeParseSingular(@NotNull final CommandSender sender, @NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
private void completeParseSingular(@NotNull final CommandSender sender,
|
||||||
{
|
@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions) {
|
||||||
if (params.size() <= 1)
|
if (params.size() <= 1) {
|
||||||
{
|
if (sender instanceof Player && (params.isEmpty() || "me"
|
||||||
if (sender instanceof Player && (params.isEmpty() || "me".startsWith(params.get(0).toLowerCase())))
|
.startsWith(params.get(0).toLowerCase()))) {
|
||||||
{
|
|
||||||
suggestions.add("me");
|
suggestions.add("me");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -187,20 +172,19 @@ public final class CommandParse extends PlaceholderCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
final String name = params.get(params.size() - 1);
|
final String name = params.get(params.size() - 1);
|
||||||
if (!name.startsWith("%") || name.endsWith("%"))
|
if (!name.startsWith("%") || name.endsWith("%")) {
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final int index = name.indexOf('_');
|
final int index = name.indexOf('_');
|
||||||
if (index == -1)
|
if (index == -1) {
|
||||||
{
|
|
||||||
return; // no arguments supplied yet
|
return; // no arguments supplied yet
|
||||||
}
|
}
|
||||||
|
|
||||||
final PlaceholderExpansion expansion = PlaceholderAPIPlugin.getInstance().getLocalExpansionManager().findExpansionByIdentifier(name.substring(1, index)).orElse(null);
|
final PlaceholderExpansion expansion = PlaceholderAPIPlugin.getInstance()
|
||||||
if (expansion == null)
|
.getLocalExpansionManager().findExpansionByIdentifier(name.substring(1, index))
|
||||||
{
|
.orElse(null);
|
||||||
|
if (expansion == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -214,10 +198,9 @@ public final class CommandParse extends PlaceholderCommand
|
|||||||
suggestByParameter(possible.stream(), suggestions, params.get(params.size() - 1));
|
suggestByParameter(possible.stream(), suggestions, params.get(params.size() - 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void completeParseRelation(@NotNull @Unmodifiable final List<String> params, @NotNull final List<String> suggestions)
|
private void completeParseRelation(@NotNull @Unmodifiable final List<String> params,
|
||||||
{
|
@NotNull final List<String> suggestions) {
|
||||||
if (params.size() > 2)
|
if (params.size() > 2) {
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -227,12 +210,10 @@ public final class CommandParse extends PlaceholderCommand
|
|||||||
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
private OfflinePlayer resolvePlayer(@NotNull final String name)
|
private OfflinePlayer resolvePlayer(@NotNull final String name) {
|
||||||
{
|
|
||||||
OfflinePlayer target = Bukkit.getPlayer(name);
|
OfflinePlayer target = Bukkit.getPlayer(name);
|
||||||
|
|
||||||
if (target == null)
|
if (target == null) {
|
||||||
{
|
|
||||||
target = Bukkit.getOfflinePlayer(name); // this is probably not a great idea.
|
target = Bukkit.getOfflinePlayer(name); // this is probably not a great idea.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,25 +20,23 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.local;
|
package me.clip.placeholderapi.commands.impl.local;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandReload extends PlaceholderCommand {
|
||||||
|
|
||||||
public final class CommandReload extends PlaceholderCommand
|
public CommandReload() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandReload()
|
|
||||||
{
|
|
||||||
super("reload");
|
super("reload");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
plugin.reloadConf(sender);
|
plugin.reloadConf(sender);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.commands.impl.local;
|
package me.clip.placeholderapi.commands.impl.local;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
import me.clip.placeholderapi.commands.PlaceholderCommand;
|
||||||
import me.clip.placeholderapi.util.Msg;
|
import me.clip.placeholderapi.util.Msg;
|
||||||
@ -28,20 +29,17 @@ import org.bukkit.plugin.PluginDescriptionFile;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.util.List;
|
public final class CommandVersion extends PlaceholderCommand {
|
||||||
|
|
||||||
public final class CommandVersion extends PlaceholderCommand
|
public CommandVersion() {
|
||||||
{
|
|
||||||
|
|
||||||
public CommandVersion()
|
|
||||||
{
|
|
||||||
super("version");
|
super("version");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin, @NotNull final CommandSender sender, @NotNull final String alias, @NotNull @Unmodifiable final List<String> params)
|
public void evaluate(@NotNull final PlaceholderAPIPlugin plugin,
|
||||||
{
|
@NotNull final CommandSender sender, @NotNull final String alias,
|
||||||
|
@NotNull @Unmodifiable final List<String> params) {
|
||||||
final PluginDescriptionFile description = plugin.getDescription();
|
final PluginDescriptionFile description = plugin.getDescription();
|
||||||
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
|
@ -20,13 +20,11 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.configuration;
|
package me.clip.placeholderapi.configuration;
|
||||||
|
|
||||||
|
import java.util.Comparator;
|
||||||
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.Comparator;
|
public enum ExpansionSort implements Comparator<CloudExpansion> {
|
||||||
|
|
||||||
public enum ExpansionSort implements Comparator<CloudExpansion>
|
|
||||||
{
|
|
||||||
|
|
||||||
NAME(Comparator.comparing(CloudExpansion::getName)),
|
NAME(Comparator.comparing(CloudExpansion::getName)),
|
||||||
AUTHOR(Comparator.comparing(CloudExpansion::getAuthor)),
|
AUTHOR(Comparator.comparing(CloudExpansion::getAuthor)),
|
||||||
@ -36,15 +34,13 @@ public enum ExpansionSort implements Comparator<CloudExpansion>
|
|||||||
@NotNull
|
@NotNull
|
||||||
private final Comparator<CloudExpansion> comparator;
|
private final Comparator<CloudExpansion> comparator;
|
||||||
|
|
||||||
ExpansionSort(@NotNull final Comparator<CloudExpansion> comparator)
|
ExpansionSort(@NotNull final Comparator<CloudExpansion> comparator) {
|
||||||
{
|
|
||||||
this.comparator = comparator;
|
this.comparator = comparator;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final int compare(final CloudExpansion expansion1, final CloudExpansion expansion2)
|
public final int compare(final CloudExpansion expansion1, final CloudExpansion expansion2) {
|
||||||
{
|
|
||||||
return comparator.compare(expansion1, expansion2);
|
return comparator.compare(expansion1, expansion2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,86 +20,72 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.configuration;
|
package me.clip.placeholderapi.configuration;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.Optional;
|
public final class PlaceholderAPIConfig {
|
||||||
|
|
||||||
public final class PlaceholderAPIConfig
|
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final PlaceholderAPIPlugin plugin;
|
private final PlaceholderAPIPlugin plugin;
|
||||||
|
|
||||||
public PlaceholderAPIConfig(@NotNull final PlaceholderAPIPlugin plugin)
|
public PlaceholderAPIConfig(@NotNull final PlaceholderAPIPlugin plugin) {
|
||||||
{
|
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public boolean checkUpdates()
|
public boolean checkUpdates() {
|
||||||
{
|
|
||||||
return plugin.getConfig().getBoolean("check_updates");
|
return plugin.getConfig().getBoolean("check_updates");
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean cloudAllowUnverifiedExpansions()
|
public boolean cloudAllowUnverifiedExpansions() {
|
||||||
{
|
|
||||||
return plugin.getConfig().getBoolean("cloud_allow_unverified_expansions");
|
return plugin.getConfig().getBoolean("cloud_allow_unverified_expansions");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public boolean isCloudEnabled()
|
public boolean isCloudEnabled() {
|
||||||
{
|
|
||||||
return plugin.getConfig().getBoolean("cloud_enabled");
|
return plugin.getConfig().getBoolean("cloud_enabled");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setCloudEnabled(boolean state)
|
public void setCloudEnabled(boolean state) {
|
||||||
{
|
|
||||||
plugin.getConfig().set("cloud_enabled", state);
|
plugin.getConfig().set("cloud_enabled", state);
|
||||||
plugin.saveConfig();
|
plugin.saveConfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public boolean isDebugMode()
|
public boolean isDebugMode() {
|
||||||
{
|
|
||||||
return plugin.getConfig().getBoolean("debug", false);
|
return plugin.getConfig().getBoolean("debug", false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public Optional<ExpansionSort> getExpansionSort()
|
public Optional<ExpansionSort> getExpansionSort() {
|
||||||
{
|
final String option = plugin.getConfig()
|
||||||
final String option = plugin.getConfig().getString("cloud_sorting", ExpansionSort.LATEST.name());
|
.getString("cloud_sorting", ExpansionSort.LATEST.name());
|
||||||
|
|
||||||
try
|
try {
|
||||||
{
|
|
||||||
//noinspection ConstantConditions (bad spigot annotation)
|
//noinspection ConstantConditions (bad spigot annotation)
|
||||||
return Optional.of(ExpansionSort.valueOf(option.toUpperCase()));
|
return Optional.of(ExpansionSort.valueOf(option.toUpperCase()));
|
||||||
}
|
} catch (final IllegalArgumentException ignored) {
|
||||||
catch (final IllegalArgumentException ignored)
|
|
||||||
{
|
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public String dateFormat()
|
public String dateFormat() {
|
||||||
{
|
|
||||||
//noinspection ConstantConditions (bad spigot annotation)
|
//noinspection ConstantConditions (bad spigot annotation)
|
||||||
return plugin.getConfig().getString("date_format", "MM/dd/yy HH:mm:ss");
|
return plugin.getConfig().getString("date_format", "MM/dd/yy HH:mm:ss");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public String booleanTrue()
|
public String booleanTrue() {
|
||||||
{
|
|
||||||
//noinspection ConstantConditions (bad spigot annotation)
|
//noinspection ConstantConditions (bad spigot annotation)
|
||||||
return plugin.getConfig().getString("boolean.true", "true");
|
return plugin.getConfig().getString("boolean.true", "true");
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public String booleanFalse()
|
public String booleanFalse() {
|
||||||
{
|
|
||||||
//noinspection ConstantConditions (bad spigot annotation)
|
//noinspection ConstantConditions (bad spigot annotation)
|
||||||
return plugin.getConfig().getString("boolean.false", "false");
|
return plugin.getConfig().getString("boolean.false", "false");
|
||||||
}
|
}
|
||||||
|
@ -26,54 +26,41 @@ import org.bukkit.event.Event;
|
|||||||
import org.bukkit.event.HandlerList;
|
import org.bukkit.event.HandlerList;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public final class ExpansionRegisterEvent extends Event implements Cancellable
|
public final class ExpansionRegisterEvent extends Event implements Cancellable {
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final HandlerList HANDLERS = new HandlerList();
|
private static final HandlerList HANDLERS = new HandlerList();
|
||||||
|
|
||||||
|
|
||||||
private boolean cancelled;
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final PlaceholderExpansion expansion;
|
private final PlaceholderExpansion expansion;
|
||||||
|
private boolean cancelled;
|
||||||
|
|
||||||
public ExpansionRegisterEvent(@NotNull final PlaceholderExpansion expansion)
|
public ExpansionRegisterEvent(@NotNull final PlaceholderExpansion expansion) {
|
||||||
{
|
|
||||||
this.expansion = expansion;
|
this.expansion = expansion;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
public static HandlerList getHandlerList() {
|
||||||
|
return HANDLERS;
|
||||||
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public PlaceholderExpansion getExpansion()
|
public PlaceholderExpansion getExpansion() {
|
||||||
{
|
|
||||||
return expansion;
|
return expansion;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isCancelled()
|
public boolean isCancelled() {
|
||||||
{
|
|
||||||
return cancelled;
|
return cancelled;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setCancelled(boolean cancelled)
|
public void setCancelled(boolean cancelled) {
|
||||||
{
|
|
||||||
this.cancelled = cancelled;
|
this.cancelled = cancelled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Override
|
@Override
|
||||||
public HandlerList getHandlers()
|
public HandlerList getHandlers() {
|
||||||
{
|
|
||||||
return HANDLERS;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
public static HandlerList getHandlerList()
|
|
||||||
{
|
|
||||||
return HANDLERS;
|
return HANDLERS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,8 +25,7 @@ import org.bukkit.event.Event;
|
|||||||
import org.bukkit.event.HandlerList;
|
import org.bukkit.event.HandlerList;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public final class ExpansionUnregisterEvent extends Event
|
public final class ExpansionUnregisterEvent extends Event {
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final HandlerList HANDLERS = new HandlerList();
|
private static final HandlerList HANDLERS = new HandlerList();
|
||||||
@ -35,30 +34,23 @@ public final class ExpansionUnregisterEvent extends Event
|
|||||||
@NotNull
|
@NotNull
|
||||||
private final PlaceholderExpansion expansion;
|
private final PlaceholderExpansion expansion;
|
||||||
|
|
||||||
public ExpansionUnregisterEvent(@NotNull final PlaceholderExpansion expansion)
|
public ExpansionUnregisterEvent(@NotNull final PlaceholderExpansion expansion) {
|
||||||
{
|
|
||||||
this.expansion = expansion;
|
this.expansion = expansion;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public PlaceholderExpansion getExpansion()
|
public static HandlerList getHandlerList() {
|
||||||
{
|
|
||||||
return expansion;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
@Override
|
|
||||||
public HandlerList getHandlers()
|
|
||||||
{
|
|
||||||
return HANDLERS;
|
return HANDLERS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
public PlaceholderExpansion getExpansion() {
|
||||||
|
return expansion;
|
||||||
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public static HandlerList getHandlerList()
|
@Override
|
||||||
{
|
public HandlerList getHandlers() {
|
||||||
return HANDLERS;
|
return HANDLERS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,8 +29,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
* @deprecated This event is no longer used.
|
* @deprecated This event is no longer used.
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public final class PlaceholderHookUnloadEvent extends Event
|
public final class PlaceholderHookUnloadEvent extends Event {
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final HandlerList HANDLERS = new HandlerList();
|
private static final HandlerList HANDLERS = new HandlerList();
|
||||||
@ -41,36 +40,30 @@ public final class PlaceholderHookUnloadEvent extends Event
|
|||||||
@NotNull
|
@NotNull
|
||||||
private final PlaceholderHook placeholderHook;
|
private final PlaceholderHook placeholderHook;
|
||||||
|
|
||||||
public PlaceholderHookUnloadEvent(@NotNull final String plugin, @NotNull final PlaceholderHook placeholderHook)
|
public PlaceholderHookUnloadEvent(@NotNull final String plugin,
|
||||||
{
|
@NotNull final PlaceholderHook placeholderHook) {
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
this.placeholderHook = placeholderHook;
|
this.placeholderHook = placeholderHook;
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public String getHookName()
|
public static HandlerList getHandlerList() {
|
||||||
{
|
return HANDLERS;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
public String getHookName() {
|
||||||
return plugin;
|
return plugin;
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public PlaceholderHook getHook()
|
public PlaceholderHook getHook() {
|
||||||
{
|
|
||||||
return placeholderHook;
|
return placeholderHook;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Override
|
@Override
|
||||||
public HandlerList getHandlers()
|
public HandlerList getHandlers() {
|
||||||
{
|
|
||||||
return HANDLERS;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
public static HandlerList getHandlerList()
|
|
||||||
{
|
|
||||||
return HANDLERS;
|
return HANDLERS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
package me.clip.placeholderapi.exceptions;
|
package me.clip.placeholderapi.exceptions;
|
||||||
|
|
||||||
public final class NoDefaultCommandException extends RuntimeException {
|
public final class NoDefaultCommandException extends RuntimeException {
|
||||||
|
|
||||||
public NoDefaultCommandException(final String message) {
|
public NoDefaultCommandException(final String message) {
|
||||||
super(message);
|
super(message);
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,9 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.expansion;
|
package me.clip.placeholderapi.expansion;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Objects;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.PlaceholderHook;
|
import me.clip.placeholderapi.PlaceholderHook;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
@ -30,12 +33,7 @@ import org.jetbrains.annotations.Contract;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.util.Collections;
|
public abstract class PlaceholderExpansion extends PlaceholderHook {
|
||||||
import java.util.List;
|
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
public abstract class PlaceholderExpansion extends PlaceholderHook
|
|
||||||
{
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The placeholder identifier of this expansion
|
* The placeholder identifier of this expansion
|
||||||
@ -63,8 +61,7 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
@Override /* override for now >:) */
|
@Override /* override for now >:) */
|
||||||
public String onRequest(@Nullable final OfflinePlayer player, @NotNull final String params)
|
public String onRequest(@Nullable final OfflinePlayer player, @NotNull final String params) {
|
||||||
{
|
|
||||||
return super.onRequest(player, params);
|
return super.onRequest(player, params);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -75,8 +72,7 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
* @return {@link #getIdentifier()} by default, name of this expansion if specified
|
* @return {@link #getIdentifier()} by default, name of this expansion if specified
|
||||||
*/
|
*/
|
||||||
@NotNull
|
@NotNull
|
||||||
public String getName()
|
public String getName() {
|
||||||
{
|
|
||||||
return getIdentifier();
|
return getIdentifier();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -86,8 +82,7 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
* @return plugin name that this expansion requires to function
|
* @return plugin name that this expansion requires to function
|
||||||
*/
|
*/
|
||||||
@Nullable
|
@Nullable
|
||||||
public String getRequiredPlugin()
|
public String getRequiredPlugin() {
|
||||||
{
|
|
||||||
return getPlugin();
|
return getPlugin();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -97,8 +92,7 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
* @return placeholder list that this expansion provides
|
* @return placeholder list that this expansion provides
|
||||||
*/
|
*/
|
||||||
@NotNull
|
@NotNull
|
||||||
public List<String> getPlaceholders()
|
public List<String> getPlaceholders() {
|
||||||
{
|
|
||||||
return Collections.emptyList();
|
return Collections.emptyList();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -110,8 +104,7 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
*
|
*
|
||||||
* @return if this expansion should persist through placeholder reloads
|
* @return if this expansion should persist through placeholder reloads
|
||||||
*/
|
*/
|
||||||
public boolean persist()
|
public boolean persist() {
|
||||||
{
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -121,9 +114,9 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
*
|
*
|
||||||
* @return true if the identifier for this expansion is already registered
|
* @return true if the identifier for this expansion is already registered
|
||||||
*/
|
*/
|
||||||
public final boolean isRegistered()
|
public final boolean isRegistered() {
|
||||||
{
|
return getPlaceholderAPI().getLocalExpansionManager().findExpansionByIdentifier(getIdentifier())
|
||||||
return getPlaceholderAPI().getLocalExpansionManager().findExpansionByIdentifier(getIdentifier()).map(it -> it.equals(this)).orElse(false);
|
.map(it -> it.equals(this)).orElse(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -133,9 +126,9 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
*
|
*
|
||||||
* @return true if this hook meets all the requirements to register
|
* @return true if this hook meets all the requirements to register
|
||||||
*/
|
*/
|
||||||
public boolean canRegister()
|
public boolean canRegister() {
|
||||||
{
|
return getRequiredPlugin() == null
|
||||||
return getRequiredPlugin() == null || Bukkit.getPluginManager().getPlugin(getRequiredPlugin()) != null;
|
|| Bukkit.getPluginManager().getPlugin(getRequiredPlugin()) != null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -143,8 +136,7 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
*
|
*
|
||||||
* @return true if this expansion is now registered with PlaceholderAPI
|
* @return true if this expansion is now registered with PlaceholderAPI
|
||||||
*/
|
*/
|
||||||
public boolean register()
|
public boolean register() {
|
||||||
{
|
|
||||||
return canRegister() && getPlaceholderAPI().getLocalExpansionManager().register(this);
|
return canRegister() && getPlaceholderAPI().getLocalExpansionManager().register(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -153,8 +145,7 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
*
|
*
|
||||||
* @return true if this expansion is now unregistered with PlaceholderAPI
|
* @return true if this expansion is now unregistered with PlaceholderAPI
|
||||||
*/
|
*/
|
||||||
public final boolean unregister()
|
public final boolean unregister() {
|
||||||
{
|
|
||||||
return getPlaceholderAPI().getLocalExpansionManager().unregister(this);
|
return getPlaceholderAPI().getLocalExpansionManager().unregister(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -165,83 +156,69 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
* @return {@link PlaceholderAPIPlugin} instance
|
* @return {@link PlaceholderAPIPlugin} instance
|
||||||
*/
|
*/
|
||||||
@NotNull
|
@NotNull
|
||||||
public final PlaceholderAPIPlugin getPlaceholderAPI()
|
public final PlaceholderAPIPlugin getPlaceholderAPI() {
|
||||||
{
|
|
||||||
return PlaceholderAPIPlugin.getInstance();
|
return PlaceholderAPIPlugin.getInstance();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// === Configuration ===
|
// === Configuration ===
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public final ConfigurationSection getConfigSection()
|
public final ConfigurationSection getConfigSection() {
|
||||||
{
|
|
||||||
return getPlaceholderAPI().getConfig().getConfigurationSection("expansions." + getIdentifier());
|
return getPlaceholderAPI().getConfig().getConfigurationSection("expansions." + getIdentifier());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public final ConfigurationSection getConfigSection(@NotNull final String path)
|
public final ConfigurationSection getConfigSection(@NotNull final String path) {
|
||||||
{
|
|
||||||
final ConfigurationSection section = getConfigSection();
|
final ConfigurationSection section = getConfigSection();
|
||||||
return section == null ? null : section.getConfigurationSection(path);
|
return section == null ? null : section.getConfigurationSection(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
@Contract("_, !null -> !null")
|
@Contract("_, !null -> !null")
|
||||||
public final Object get(@NotNull final String path, final Object def)
|
public final Object get(@NotNull final String path, final Object def) {
|
||||||
{
|
|
||||||
final ConfigurationSection section = getConfigSection();
|
final ConfigurationSection section = getConfigSection();
|
||||||
return section == null ? def : section.get(path, def);
|
return section == null ? def : section.get(path, def);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final int getInt(@NotNull final String path, final int def)
|
public final int getInt(@NotNull final String path, final int def) {
|
||||||
{
|
|
||||||
final ConfigurationSection section = getConfigSection();
|
final ConfigurationSection section = getConfigSection();
|
||||||
return section == null ? def : section.getInt(path, def);
|
return section == null ? def : section.getInt(path, def);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final long getLong(@NotNull final String path, final long def)
|
public final long getLong(@NotNull final String path, final long def) {
|
||||||
{
|
|
||||||
final ConfigurationSection section = getConfigSection();
|
final ConfigurationSection section = getConfigSection();
|
||||||
return section == null ? def : section.getLong(path, def);
|
return section == null ? def : section.getLong(path, def);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final double getDouble(@NotNull final String path, final double def)
|
public final double getDouble(@NotNull final String path, final double def) {
|
||||||
{
|
|
||||||
final ConfigurationSection section = getConfigSection();
|
final ConfigurationSection section = getConfigSection();
|
||||||
return section == null ? def : section.getDouble(path, def);
|
return section == null ? def : section.getDouble(path, def);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
@Contract("_, !null -> !null")
|
@Contract("_, !null -> !null")
|
||||||
public final String getString(@NotNull final String path, @Nullable final String def)
|
public final String getString(@NotNull final String path, @Nullable final String def) {
|
||||||
{
|
|
||||||
final ConfigurationSection section = getConfigSection();
|
final ConfigurationSection section = getConfigSection();
|
||||||
return section == null ? def : section.getString(path, def);
|
return section == null ? def : section.getString(path, def);
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public final List<String> getStringList(@NotNull final String path)
|
public final List<String> getStringList(@NotNull final String path) {
|
||||||
{
|
|
||||||
final ConfigurationSection section = getConfigSection();
|
final ConfigurationSection section = getConfigSection();
|
||||||
return section == null ? Collections.emptyList() : section.getStringList(path);
|
return section == null ? Collections.emptyList() : section.getStringList(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final boolean configurationContains(@NotNull final String path)
|
public final boolean configurationContains(@NotNull final String path) {
|
||||||
{
|
|
||||||
final ConfigurationSection section = getConfigSection();
|
final ConfigurationSection section = getConfigSection();
|
||||||
return section != null && section.contains(path);
|
return section != null && section.contains(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final boolean equals(final Object o)
|
public final boolean equals(final Object o) {
|
||||||
{
|
if (this == o) {
|
||||||
if (this == o)
|
|
||||||
{
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (!(o instanceof PlaceholderExpansion))
|
if (!(o instanceof PlaceholderExpansion)) {
|
||||||
{
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -253,15 +230,14 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final int hashCode()
|
public final int hashCode() {
|
||||||
{
|
|
||||||
return Objects.hash(getIdentifier(), getAuthor(), getVersion());
|
return Objects.hash(getIdentifier(), getAuthor(), getVersion());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final String toString()
|
public final String toString() {
|
||||||
{
|
return String.format("PlaceholderExpansion[name: '%s', author: '%s', version: '%s']", getName(),
|
||||||
return String.format("PlaceholderExpansion[name: '%s', author: '%s', version: '%s']", getName(), getAuthor(), getVersion());
|
getAuthor(), getVersion());
|
||||||
}
|
}
|
||||||
|
|
||||||
// === Deprecated API ===
|
// === Deprecated API ===
|
||||||
@ -271,8 +247,7 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
@ApiStatus.ScheduledForRemoval(inVersion = "2.11.0")
|
@ApiStatus.ScheduledForRemoval(inVersion = "2.11.0")
|
||||||
public String getPlugin()
|
public String getPlugin() {
|
||||||
{
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -281,8 +256,7 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
@ApiStatus.ScheduledForRemoval(inVersion = "2.11.0")
|
@ApiStatus.ScheduledForRemoval(inVersion = "2.11.0")
|
||||||
public String getDescription()
|
public String getDescription() {
|
||||||
{
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -291,8 +265,7 @@ public abstract class PlaceholderExpansion extends PlaceholderHook
|
|||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
@ApiStatus.ScheduledForRemoval(inVersion = "2.11.0")
|
@ApiStatus.ScheduledForRemoval(inVersion = "2.11.0")
|
||||||
public String getLink()
|
public String getLink() {
|
||||||
{
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,11 +20,10 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.expansion.cloud;
|
package me.clip.placeholderapi.expansion.cloud;
|
||||||
|
|
||||||
import me.clip.placeholderapi.util.TimeUtil;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
import me.clip.placeholderapi.util.TimeUtil;
|
||||||
|
|
||||||
|
|
||||||
public class CloudExpansion {
|
public class CloudExpansion {
|
||||||
@ -173,6 +172,7 @@ public class CloudExpansion {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public class Version {
|
public class Version {
|
||||||
|
|
||||||
private String url, version, release_notes;
|
private String url, version, release_notes;
|
||||||
|
|
||||||
public String getUrl() {
|
public String getUrl() {
|
||||||
|
@ -24,12 +24,6 @@ import com.google.common.collect.ImmutableMap;
|
|||||||
import com.google.common.io.Resources;
|
import com.google.common.io.Resources;
|
||||||
import com.google.gson.Gson;
|
import com.google.gson.Gson;
|
||||||
import com.google.gson.reflect.TypeToken;
|
import com.google.gson.reflect.TypeToken;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
|
||||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
|
||||||
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
@ -38,7 +32,11 @@ import java.net.URL;
|
|||||||
import java.nio.channels.Channels;
|
import java.nio.channels.Channels;
|
||||||
import java.nio.channels.ReadableByteChannel;
|
import java.nio.channels.ReadableByteChannel;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.*;
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.concurrent.CompletableFuture;
|
import java.util.concurrent.CompletableFuture;
|
||||||
import java.util.concurrent.CompletionException;
|
import java.util.concurrent.CompletionException;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
@ -46,9 +44,13 @@ import java.util.function.Function;
|
|||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
import java.util.stream.Collector;
|
import java.util.stream.Collector;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||||
|
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
public final class CloudExpansionManager
|
public final class CloudExpansionManager {
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final String API_URL = "http://api.extendedclip.com/v2/";
|
private static final String API_URL = "http://api.extendedclip.com/v2/";
|
||||||
@ -59,7 +61,8 @@ public final class CloudExpansionManager
|
|||||||
private static final Type TYPE = new TypeToken<Map<String, CloudExpansion>>() {}.getType();
|
private static final Type TYPE = new TypeToken<Map<String, CloudExpansion>>() {}.getType();
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final Collector<CloudExpansion, ?, Map<String, CloudExpansion>> INDEXED_NAME_COLLECTOR = Collectors.toMap(CloudExpansionManager::toIndexName, Function.identity());
|
private final Collector<CloudExpansion, ?, Map<String, CloudExpansion>> INDEXED_NAME_COLLECTOR = Collectors
|
||||||
|
.toMap(CloudExpansionManager::toIndexName, Function.identity());
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@ -71,37 +74,39 @@ public final class CloudExpansionManager
|
|||||||
private final Map<String, CompletableFuture<File>> await = new ConcurrentHashMap<>();
|
private final Map<String, CompletableFuture<File>> await = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
|
|
||||||
public CloudExpansionManager(@NotNull final PlaceholderAPIPlugin plugin)
|
public CloudExpansionManager(@NotNull final PlaceholderAPIPlugin plugin) {
|
||||||
{
|
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private static String toIndexName(@NotNull final String name) {
|
||||||
|
return name.toLowerCase().replace(' ', '_');
|
||||||
|
}
|
||||||
|
|
||||||
public void load()
|
@NotNull
|
||||||
{
|
private static String toIndexName(@NotNull final CloudExpansion expansion) {
|
||||||
|
return toIndexName(expansion.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
public void load() {
|
||||||
clean();
|
clean();
|
||||||
fetch(plugin.getPlaceholderAPIConfig().cloudAllowUnverifiedExpansions());
|
fetch(plugin.getPlaceholderAPIConfig().cloudAllowUnverifiedExpansions());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void kill()
|
public void kill() {
|
||||||
{
|
|
||||||
clean();
|
clean();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
public Map<String, CloudExpansion> getCloudExpansions()
|
public Map<String, CloudExpansion> getCloudExpansions() {
|
||||||
{
|
|
||||||
return ImmutableMap.copyOf(cache);
|
return ImmutableMap.copyOf(cache);
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
public Map<String, CloudExpansion> getCloudExpansionsInstalled()
|
public Map<String, CloudExpansion> getCloudExpansionsInstalled() {
|
||||||
{
|
if (cache.isEmpty()) {
|
||||||
if (cache.isEmpty())
|
|
||||||
{
|
|
||||||
return Collections.emptyMap();
|
return Collections.emptyMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,10 +118,8 @@ public final class CloudExpansionManager
|
|||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
public Map<String, CloudExpansion> getCloudExpansionsByAuthor(@NotNull final String author)
|
public Map<String, CloudExpansion> getCloudExpansionsByAuthor(@NotNull final String author) {
|
||||||
{
|
if (cache.isEmpty()) {
|
||||||
if (cache.isEmpty())
|
|
||||||
{
|
|
||||||
return Collections.emptyMap();
|
return Collections.emptyMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,83 +131,70 @@ public final class CloudExpansionManager
|
|||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
public Set<String> getCloudExpansionAuthors()
|
public Set<String> getCloudExpansionAuthors() {
|
||||||
{
|
|
||||||
return cache.values().stream().map(CloudExpansion::getAuthor).collect(Collectors.toSet());
|
return cache.values().stream().map(CloudExpansion::getAuthor).collect(Collectors.toSet());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int getCloudExpansionAuthorCount() {
|
||||||
public int getCloudExpansionAuthorCount()
|
|
||||||
{
|
|
||||||
return getCloudExpansionAuthors().size();
|
return getCloudExpansionAuthors().size();
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getCloudUpdateCount()
|
public int getCloudUpdateCount() {
|
||||||
{
|
|
||||||
return ((int) plugin.getLocalExpansionManager()
|
return ((int) plugin.getLocalExpansionManager()
|
||||||
.getExpansions()
|
.getExpansions()
|
||||||
.stream()
|
.stream()
|
||||||
.filter(expansion -> findCloudExpansionByName(expansion.getName()).map(CloudExpansion::shouldUpdate).orElse(false))
|
.filter(expansion -> findCloudExpansionByName(expansion.getName())
|
||||||
|
.map(CloudExpansion::shouldUpdate).orElse(false))
|
||||||
.count());
|
.count());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public Optional<CloudExpansion> findCloudExpansionByName(@NotNull final String name)
|
public Optional<CloudExpansion> findCloudExpansionByName(@NotNull final String name) {
|
||||||
{
|
|
||||||
return Optional.ofNullable(cache.get(toIndexName(name)));
|
return Optional.ofNullable(cache.get(toIndexName(name)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void clean() {
|
||||||
public void clean()
|
|
||||||
{
|
|
||||||
cache.clear();
|
cache.clear();
|
||||||
|
|
||||||
await.values().forEach(future -> future.cancel(true));
|
await.values().forEach(future -> future.cancel(true));
|
||||||
await.clear();
|
await.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void fetch(final boolean allowUnverified)
|
public void fetch(final boolean allowUnverified) {
|
||||||
{
|
|
||||||
plugin.getLogger().info("Fetching available expansion information...");
|
plugin.getLogger().info("Fetching available expansion information...");
|
||||||
|
|
||||||
CompletableFuture<Map<String, CloudExpansion>> future = CompletableFuture.supplyAsync(() -> {
|
CompletableFuture<Map<String, CloudExpansion>> future = CompletableFuture.supplyAsync(() -> {
|
||||||
final Map<String, CloudExpansion> values = new HashMap<>();
|
final Map<String, CloudExpansion> values = new HashMap<>();
|
||||||
|
|
||||||
try
|
try {
|
||||||
{
|
|
||||||
//noinspection UnstableApiUsage
|
//noinspection UnstableApiUsage
|
||||||
final String json = Resources.toString(new URL(API_URL), StandardCharsets.UTF_8);
|
final String json = Resources.toString(new URL(API_URL), StandardCharsets.UTF_8);
|
||||||
values.putAll(GSON.fromJson(json, TYPE));
|
values.putAll(GSON.fromJson(json, TYPE));
|
||||||
}
|
} catch (final IOException ex) {
|
||||||
catch (final IOException ex)
|
|
||||||
{
|
|
||||||
throw new CompletionException(ex);
|
throw new CompletionException(ex);
|
||||||
}
|
}
|
||||||
|
|
||||||
values.values().removeIf(value -> value.getLatestVersion() == null || value.getVersion(value.getLatestVersion()) == null);
|
values.values().removeIf(value -> value.getLatestVersion() == null
|
||||||
|
|| value.getVersion(value.getLatestVersion()) == null);
|
||||||
|
|
||||||
return values;
|
return values;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (!allowUnverified) {
|
||||||
if (!allowUnverified)
|
|
||||||
{
|
|
||||||
future = future.thenApplyAsync((values) -> {
|
future = future.thenApplyAsync((values) -> {
|
||||||
values.values().removeIf(expansion -> !expansion.isVerified());
|
values.values().removeIf(expansion -> !expansion.isVerified());
|
||||||
return values;
|
return values;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
future = future.thenApplyAsync((values) -> {
|
future = future.thenApplyAsync((values) -> {
|
||||||
|
|
||||||
values.forEach((name, expansion) -> {
|
values.forEach((name, expansion) -> {
|
||||||
expansion.setName(name);
|
expansion.setName(name);
|
||||||
|
|
||||||
final Optional<PlaceholderExpansion> local = plugin.getLocalExpansionManager().findExpansionByName(name);
|
final Optional<PlaceholderExpansion> local = plugin.getLocalExpansionManager()
|
||||||
if (local.isPresent() && local.get().isRegistered())
|
.findExpansionByName(name);
|
||||||
{
|
if (local.isPresent() && local.get().isRegistered()) {
|
||||||
expansion.setHasExpansion(true);
|
expansion.setHasExpansion(true);
|
||||||
expansion.setShouldUpdate(!local.get().getVersion().equals(expansion.getLatestVersion()));
|
expansion.setShouldUpdate(!local.get().getVersion().equals(expansion.getLatestVersion()));
|
||||||
}
|
}
|
||||||
@ -215,44 +205,38 @@ public final class CloudExpansionManager
|
|||||||
|
|
||||||
future.whenComplete((expansions, exception) -> {
|
future.whenComplete((expansions, exception) -> {
|
||||||
|
|
||||||
if (exception != null)
|
if (exception != null) {
|
||||||
{
|
plugin.getLogger()
|
||||||
plugin.getLogger().log(Level.WARNING, "failed to download expansion information", exception);
|
.log(Level.WARNING, "failed to download expansion information", exception);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (final CloudExpansion expansion : expansions.values())
|
for (final CloudExpansion expansion : expansions.values()) {
|
||||||
{
|
|
||||||
this.cache.put(toIndexName(expansion), expansion);
|
this.cache.put(toIndexName(expansion), expansion);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isDownloading(@NotNull final CloudExpansion expansion) {
|
||||||
public boolean isDownloading(@NotNull final CloudExpansion expansion)
|
|
||||||
{
|
|
||||||
return await.containsKey(toIndexName(expansion));
|
return await.containsKey(toIndexName(expansion));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public CompletableFuture<File> downloadExpansion(@NotNull final CloudExpansion expansion, @NotNull final CloudExpansion.Version version)
|
public CompletableFuture<File> downloadExpansion(@NotNull final CloudExpansion expansion,
|
||||||
{
|
@NotNull final CloudExpansion.Version version) {
|
||||||
final CompletableFuture<File> previous = await.get(toIndexName(expansion));
|
final CompletableFuture<File> previous = await.get(toIndexName(expansion));
|
||||||
if (previous != null)
|
if (previous != null) {
|
||||||
{
|
|
||||||
return previous;
|
return previous;
|
||||||
}
|
}
|
||||||
|
|
||||||
final File file = new File(plugin.getLocalExpansionManager().getExpansionsFolder(), "Expansion-" + toIndexName(expansion) + ".jar");
|
final File file = new File(plugin.getLocalExpansionManager().getExpansionsFolder(),
|
||||||
|
"Expansion-" + toIndexName(expansion) + ".jar");
|
||||||
|
|
||||||
final CompletableFuture<File> download = CompletableFuture.supplyAsync(() -> {
|
final CompletableFuture<File> download = CompletableFuture.supplyAsync(() -> {
|
||||||
try (final ReadableByteChannel source = Channels.newChannel(new URL(version.getUrl()).openStream()); final FileOutputStream target = new FileOutputStream(file))
|
try (final ReadableByteChannel source = Channels.newChannel(new URL(version.getUrl())
|
||||||
{
|
.openStream()); final FileOutputStream target = new FileOutputStream(file)) {
|
||||||
target.getChannel().transferFrom(source, 0, Long.MAX_VALUE);
|
target.getChannel().transferFrom(source, 0, Long.MAX_VALUE);
|
||||||
}
|
} catch (final IOException ex) {
|
||||||
catch (final IOException ex)
|
|
||||||
{
|
|
||||||
throw new CompletionException(ex);
|
throw new CompletionException(ex);
|
||||||
}
|
}
|
||||||
return file;
|
return file;
|
||||||
@ -261,9 +245,9 @@ public final class CloudExpansionManager
|
|||||||
download.whenCompleteAsync((value, exception) -> {
|
download.whenCompleteAsync((value, exception) -> {
|
||||||
await.remove(toIndexName(expansion));
|
await.remove(toIndexName(expansion));
|
||||||
|
|
||||||
if (exception != null)
|
if (exception != null) {
|
||||||
{
|
plugin.getLogger().log(Level.SEVERE,
|
||||||
plugin.getLogger().log(Level.SEVERE, "failed to download " + expansion.getName() + ":" + version.getVersion(), exception);
|
"failed to download " + expansion.getName() + ":" + version.getVersion(), exception);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -272,17 +256,4 @@ public final class CloudExpansionManager
|
|||||||
return download;
|
return download;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
private static String toIndexName(@NotNull final String name)
|
|
||||||
{
|
|
||||||
return name.toLowerCase().replace(' ', '_');
|
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
private static String toIndexName(@NotNull final CloudExpansion expansion)
|
|
||||||
{
|
|
||||||
return toIndexName(expansion.getName());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -22,10 +22,25 @@ package me.clip.placeholderapi.expansion.manager;
|
|||||||
|
|
||||||
import com.google.common.collect.ImmutableSet;
|
import com.google.common.collect.ImmutableSet;
|
||||||
import com.google.common.collect.Sets;
|
import com.google.common.collect.Sets;
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
import java.util.concurrent.CompletionException;
|
||||||
|
import java.util.logging.Level;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.events.ExpansionRegisterEvent;
|
import me.clip.placeholderapi.events.ExpansionRegisterEvent;
|
||||||
import me.clip.placeholderapi.events.ExpansionUnregisterEvent;
|
import me.clip.placeholderapi.events.ExpansionUnregisterEvent;
|
||||||
import me.clip.placeholderapi.expansion.*;
|
import me.clip.placeholderapi.expansion.Cacheable;
|
||||||
|
import me.clip.placeholderapi.expansion.Cleanable;
|
||||||
|
import me.clip.placeholderapi.expansion.Configurable;
|
||||||
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||||
|
import me.clip.placeholderapi.expansion.Taskable;
|
||||||
|
import me.clip.placeholderapi.expansion.VersionSpecific;
|
||||||
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
import me.clip.placeholderapi.expansion.cloud.CloudExpansion;
|
||||||
import me.clip.placeholderapi.util.FileUtil;
|
import me.clip.placeholderapi.util.FileUtil;
|
||||||
import me.clip.placeholderapi.util.Futures;
|
import me.clip.placeholderapi.util.Futures;
|
||||||
@ -44,19 +59,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
import org.jetbrains.annotations.Unmodifiable;
|
import org.jetbrains.annotations.Unmodifiable;
|
||||||
|
|
||||||
import java.io.File;
|
public final class LocalExpansionManager implements Listener {
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Optional;
|
|
||||||
import java.util.concurrent.CompletableFuture;
|
|
||||||
import java.util.concurrent.CompletionException;
|
|
||||||
import java.util.logging.Level;
|
|
||||||
|
|
||||||
public final class LocalExpansionManager implements Listener
|
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static final String EXPANSIONS_FOLDER_NAME = "expansions";
|
private static final String EXPANSIONS_FOLDER_NAME = "expansions";
|
||||||
@ -71,91 +74,79 @@ public final class LocalExpansionManager implements Listener
|
|||||||
private final Map<String, PlaceholderExpansion> expansions = new HashMap<>();
|
private final Map<String, PlaceholderExpansion> expansions = new HashMap<>();
|
||||||
|
|
||||||
|
|
||||||
public LocalExpansionManager(@NotNull final PlaceholderAPIPlugin plugin)
|
public LocalExpansionManager(@NotNull final PlaceholderAPIPlugin plugin) {
|
||||||
{
|
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
this.folder = new File(plugin.getDataFolder(), EXPANSIONS_FOLDER_NAME);
|
this.folder = new File(plugin.getDataFolder(), EXPANSIONS_FOLDER_NAME);
|
||||||
|
|
||||||
if (!this.folder.exists() && !folder.mkdirs())
|
if (!this.folder.exists() && !folder.mkdirs()) {
|
||||||
{
|
|
||||||
plugin.getLogger().log(Level.WARNING, "failed to create expansions folder!");
|
plugin.getLogger().log(Level.WARNING, "failed to create expansions folder!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void load(@NotNull final CommandSender sender)
|
public void load(@NotNull final CommandSender sender) {
|
||||||
{
|
|
||||||
registerAll(sender);
|
registerAll(sender);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void kill()
|
public void kill() {
|
||||||
{
|
|
||||||
unregisterAll();
|
unregisterAll();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public File getExpansionsFolder()
|
public File getExpansionsFolder() {
|
||||||
{
|
|
||||||
return folder;
|
return folder;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getExpansionsCount()
|
public int getExpansionsCount() {
|
||||||
{
|
|
||||||
return expansions.size();
|
return expansions.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
public Collection<String> getIdentifiers()
|
public Collection<String> getIdentifiers() {
|
||||||
{
|
|
||||||
return ImmutableSet.copyOf(expansions.keySet());
|
return ImmutableSet.copyOf(expansions.keySet());
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Unmodifiable
|
@Unmodifiable
|
||||||
public Collection<PlaceholderExpansion> getExpansions()
|
public Collection<PlaceholderExpansion> getExpansions() {
|
||||||
{
|
|
||||||
return ImmutableSet.copyOf(expansions.values());
|
return ImmutableSet.copyOf(expansions.values());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public PlaceholderExpansion getExpansion(@NotNull final String identifier)
|
public PlaceholderExpansion getExpansion(@NotNull final String identifier) {
|
||||||
{
|
|
||||||
return expansions.get(identifier.toLowerCase());
|
return expansions.get(identifier.toLowerCase());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public Optional<PlaceholderExpansion> findExpansionByName(@NotNull final String name)
|
public Optional<PlaceholderExpansion> findExpansionByName(@NotNull final String name) {
|
||||||
{
|
return expansions.values().stream()
|
||||||
return expansions.values().stream().filter(expansion -> name.equalsIgnoreCase(expansion.getName())).findFirst();
|
.filter(expansion -> name.equalsIgnoreCase(expansion.getName())).findFirst();
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public Optional<PlaceholderExpansion> findExpansionByIdentifier(@NotNull final String identifier)
|
public Optional<PlaceholderExpansion> findExpansionByIdentifier(
|
||||||
{
|
@NotNull final String identifier) {
|
||||||
return Optional.ofNullable(getExpansion(identifier));
|
return Optional.ofNullable(getExpansion(identifier));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public Optional<PlaceholderExpansion> register(@NotNull final Class<? extends PlaceholderExpansion> clazz)
|
public Optional<PlaceholderExpansion> register(
|
||||||
{
|
@NotNull final Class<? extends PlaceholderExpansion> clazz) {
|
||||||
try
|
try {
|
||||||
{
|
|
||||||
final PlaceholderExpansion expansion = createExpansionInstance(clazz);
|
final PlaceholderExpansion expansion = createExpansionInstance(clazz);
|
||||||
if (expansion == null || !expansion.register())
|
if (expansion == null || !expansion.register()) {
|
||||||
{
|
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
return Optional.of(expansion);
|
return Optional.of(expansion);
|
||||||
}
|
} catch (final LinkageError ex) {
|
||||||
catch (final LinkageError ex)
|
|
||||||
{
|
|
||||||
plugin.getLogger().severe("expansion class " + clazz.getSimpleName() + " is outdated: \n" +
|
plugin.getLogger().severe("expansion class " + clazz.getSimpleName() + " is outdated: \n" +
|
||||||
"Failed to load due to a [" + ex.getClass().getSimpleName() + "], attempted to use " + ex.getMessage());
|
"Failed to load due to a [" + ex.getClass().getSimpleName() + "], attempted to use " + ex
|
||||||
|
.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
@ -165,38 +156,28 @@ public final class LocalExpansionManager implements Listener
|
|||||||
* Do not call this method yourself, use {@link PlaceholderExpansion#register()}
|
* Do not call this method yourself, use {@link PlaceholderExpansion#register()}
|
||||||
*/
|
*/
|
||||||
@ApiStatus.Internal
|
@ApiStatus.Internal
|
||||||
public boolean register(@NotNull final PlaceholderExpansion expansion)
|
public boolean register(@NotNull final PlaceholderExpansion expansion) {
|
||||||
{
|
|
||||||
final String identifier = expansion.getIdentifier().toLowerCase();
|
final String identifier = expansion.getIdentifier().toLowerCase();
|
||||||
|
|
||||||
if (expansion instanceof Configurable)
|
if (expansion instanceof Configurable) {
|
||||||
{
|
|
||||||
Map<String, Object> defaults = ((Configurable) expansion).getDefaults();
|
Map<String, Object> defaults = ((Configurable) expansion).getDefaults();
|
||||||
String pre = "expansions." + identifier + ".";
|
String pre = "expansions." + identifier + ".";
|
||||||
FileConfiguration cfg = plugin.getConfig();
|
FileConfiguration cfg = plugin.getConfig();
|
||||||
boolean save = false;
|
boolean save = false;
|
||||||
|
|
||||||
if (defaults != null)
|
if (defaults != null) {
|
||||||
{
|
for (Map.Entry<String, Object> entries : defaults.entrySet()) {
|
||||||
for (Map.Entry<String, Object> entries : defaults.entrySet())
|
if (entries.getKey() == null || entries.getKey().isEmpty()) {
|
||||||
{
|
|
||||||
if (entries.getKey() == null || entries.getKey().isEmpty())
|
|
||||||
{
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (entries.getValue() == null)
|
if (entries.getValue() == null) {
|
||||||
{
|
if (cfg.contains(pre + entries.getKey())) {
|
||||||
if (cfg.contains(pre + entries.getKey()))
|
|
||||||
{
|
|
||||||
save = true;
|
save = true;
|
||||||
cfg.set(pre + entries.getKey(), null);
|
cfg.set(pre + entries.getKey(), null);
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else
|
if (!cfg.contains(pre + entries.getKey())) {
|
||||||
{
|
|
||||||
if (!cfg.contains(pre + entries.getKey()))
|
|
||||||
{
|
|
||||||
save = true;
|
save = true;
|
||||||
cfg.set(pre + entries.getKey(), entries.getValue());
|
cfg.set(pre + entries.getKey(), entries.getValue());
|
||||||
}
|
}
|
||||||
@ -204,58 +185,53 @@ public final class LocalExpansionManager implements Listener
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (save)
|
if (save) {
|
||||||
{
|
|
||||||
plugin.saveConfig();
|
plugin.saveConfig();
|
||||||
plugin.reloadConfig();
|
plugin.reloadConfig();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (expansion instanceof VersionSpecific)
|
if (expansion instanceof VersionSpecific) {
|
||||||
{
|
|
||||||
VersionSpecific nms = (VersionSpecific) expansion;
|
VersionSpecific nms = (VersionSpecific) expansion;
|
||||||
if (!nms.isCompatibleWith(PlaceholderAPIPlugin.getServerVersion()))
|
if (!nms.isCompatibleWith(PlaceholderAPIPlugin.getServerVersion())) {
|
||||||
{
|
plugin.getLogger().info(
|
||||||
plugin.getLogger().info("Your server version is not compatible with expansion: " + expansion.getIdentifier() + " version: " + expansion.getVersion());
|
"Your server version is not compatible with expansion: " + expansion.getIdentifier()
|
||||||
|
+ " version: " + expansion.getVersion());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
final PlaceholderExpansion removed = expansions.get(identifier);
|
final PlaceholderExpansion removed = expansions.get(identifier);
|
||||||
if (removed != null && !removed.unregister())
|
if (removed != null && !removed.unregister()) {
|
||||||
{
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
final ExpansionRegisterEvent event = new ExpansionRegisterEvent(expansion);
|
final ExpansionRegisterEvent event = new ExpansionRegisterEvent(expansion);
|
||||||
Bukkit.getPluginManager().callEvent(event);
|
Bukkit.getPluginManager().callEvent(event);
|
||||||
|
|
||||||
if (event.isCancelled())
|
if (event.isCancelled()) {
|
||||||
{
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
expansions.put(identifier, expansion);
|
expansions.put(identifier, expansion);
|
||||||
|
|
||||||
if (expansion instanceof Listener)
|
if (expansion instanceof Listener) {
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().registerEvents(((Listener) expansion), plugin);
|
Bukkit.getPluginManager().registerEvents(((Listener) expansion), plugin);
|
||||||
}
|
}
|
||||||
|
|
||||||
plugin.getLogger().info("Successfully registered expansion: " + expansion.getIdentifier());
|
plugin.getLogger().info("Successfully registered expansion: " + expansion.getIdentifier());
|
||||||
|
|
||||||
if (expansion instanceof Taskable)
|
if (expansion instanceof Taskable) {
|
||||||
{
|
|
||||||
((Taskable) expansion).start();
|
((Taskable) expansion).start();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (plugin.getPlaceholderAPIConfig().isCloudEnabled())
|
if (plugin.getPlaceholderAPIConfig().isCloudEnabled()) {
|
||||||
{
|
final Optional<CloudExpansion> cloudExpansion = plugin.getCloudExpansionManager()
|
||||||
final Optional<CloudExpansion> cloudExpansion = plugin.getCloudExpansionManager().findCloudExpansionByName(identifier);
|
.findCloudExpansionByName(identifier);
|
||||||
if (cloudExpansion.isPresent())
|
if (cloudExpansion.isPresent()) {
|
||||||
{
|
|
||||||
cloudExpansion.get().setHasExpansion(true);
|
cloudExpansion.get().setHasExpansion(true);
|
||||||
cloudExpansion.get().setShouldUpdate(!cloudExpansion.get().getLatestVersion().equals(expansion.getVersion()));
|
cloudExpansion.get().setShouldUpdate(
|
||||||
|
!cloudExpansion.get().getLatestVersion().equals(expansion.getVersion()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -266,35 +242,28 @@ public final class LocalExpansionManager implements Listener
|
|||||||
* Do not call this method yourself, use {@link PlaceholderExpansion#unregister()}
|
* Do not call this method yourself, use {@link PlaceholderExpansion#unregister()}
|
||||||
*/
|
*/
|
||||||
@ApiStatus.Internal
|
@ApiStatus.Internal
|
||||||
public boolean unregister(@NotNull final PlaceholderExpansion expansion)
|
public boolean unregister(@NotNull final PlaceholderExpansion expansion) {
|
||||||
{
|
if (expansions.remove(expansion.getIdentifier()) == null) {
|
||||||
if (expansions.remove(expansion.getIdentifier()) == null)
|
|
||||||
{
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Bukkit.getPluginManager().callEvent(new ExpansionUnregisterEvent(expansion));
|
Bukkit.getPluginManager().callEvent(new ExpansionUnregisterEvent(expansion));
|
||||||
|
|
||||||
|
if (expansion instanceof Listener) {
|
||||||
if (expansion instanceof Listener)
|
|
||||||
{
|
|
||||||
HandlerList.unregisterAll((Listener) expansion);
|
HandlerList.unregisterAll((Listener) expansion);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (expansion instanceof Taskable)
|
if (expansion instanceof Taskable) {
|
||||||
{
|
|
||||||
((Taskable) expansion).stop();
|
((Taskable) expansion).stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (expansion instanceof Cacheable)
|
if (expansion instanceof Cacheable) {
|
||||||
{
|
|
||||||
((Cacheable) expansion).clear();
|
((Cacheable) expansion).clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (plugin.getPlaceholderAPIConfig().isCloudEnabled())
|
if (plugin.getPlaceholderAPIConfig().isCloudEnabled()) {
|
||||||
{
|
plugin.getCloudExpansionManager().findCloudExpansionByName(expansion.getName())
|
||||||
plugin.getCloudExpansionManager().findCloudExpansionByName(expansion.getName()).ifPresent(cloud -> {
|
.ifPresent(cloud -> {
|
||||||
cloud.setHasExpansion(false);
|
cloud.setHasExpansion(false);
|
||||||
cloud.setShouldUpdate(false);
|
cloud.setShouldUpdate(false);
|
||||||
});
|
});
|
||||||
@ -304,30 +273,27 @@ public final class LocalExpansionManager implements Listener
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void registerAll(@NotNull final CommandSender sender)
|
private void registerAll(@NotNull final CommandSender sender) {
|
||||||
{
|
|
||||||
plugin.getLogger().info("Placeholder expansion registration initializing...");
|
plugin.getLogger().info("Placeholder expansion registration initializing...");
|
||||||
|
|
||||||
Futures.onMainThread(plugin, findExpansionsOnDisk(), (classes, exception) -> {
|
Futures.onMainThread(plugin, findExpansionsOnDisk(), (classes, exception) -> {
|
||||||
if (exception != null)
|
if (exception != null) {
|
||||||
{
|
|
||||||
plugin.getLogger().log(Level.SEVERE, "failed to load class files of expansions", exception);
|
plugin.getLogger().log(Level.SEVERE, "failed to load class files of expansions", exception);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final long registered = classes.stream().map(this::register).filter(Optional::isPresent).count();
|
final long registered = classes.stream().map(this::register).filter(Optional::isPresent)
|
||||||
|
.count();
|
||||||
|
|
||||||
Msg.msg(sender,
|
Msg.msg(sender,
|
||||||
registered == 0 ? "&6No expansions were registered!" : registered + "&a placeholder hooks successfully registered!");
|
registered == 0 ? "&6No expansions were registered!"
|
||||||
|
: registered + "&a placeholder hooks successfully registered!");
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private void unregisterAll()
|
private void unregisterAll() {
|
||||||
{
|
for (final PlaceholderExpansion expansion : Sets.newHashSet(expansions.values())) {
|
||||||
for (final PlaceholderExpansion expansion : Sets.newHashSet(expansions.values()))
|
if (expansion.persist()) {
|
||||||
{
|
|
||||||
if (expansion.persist())
|
|
||||||
{
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -337,29 +303,24 @@ public final class LocalExpansionManager implements Listener
|
|||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public CompletableFuture<@NotNull List<@NotNull Class<? extends PlaceholderExpansion>>> findExpansionsOnDisk()
|
public CompletableFuture<@NotNull List<@NotNull Class<? extends PlaceholderExpansion>>> findExpansionsOnDisk() {
|
||||||
{
|
|
||||||
return Arrays.stream(folder.listFiles((dir, name) -> name.endsWith(".jar")))
|
return Arrays.stream(folder.listFiles((dir, name) -> name.endsWith(".jar")))
|
||||||
.map(this::findExpansionInFile)
|
.map(this::findExpansionInFile)
|
||||||
.collect(Futures.collector());
|
.collect(Futures.collector());
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public CompletableFuture<@Nullable Class<? extends PlaceholderExpansion>> findExpansionInFile(@NotNull final File file)
|
public CompletableFuture<@Nullable Class<? extends PlaceholderExpansion>> findExpansionInFile(
|
||||||
{
|
@NotNull final File file) {
|
||||||
return CompletableFuture.supplyAsync(() -> {
|
return CompletableFuture.supplyAsync(() -> {
|
||||||
try
|
try {
|
||||||
{
|
|
||||||
return FileUtil.findClass(file, PlaceholderExpansion.class);
|
return FileUtil.findClass(file, PlaceholderExpansion.class);
|
||||||
}
|
} catch (final VerifyError ex) {
|
||||||
catch (final VerifyError ex)
|
|
||||||
{
|
|
||||||
plugin.getLogger().severe("expansion file " + file.getName() + " is outdated: \n" +
|
plugin.getLogger().severe("expansion file " + file.getName() + " is outdated: \n" +
|
||||||
"Failed to load due to a [" + ex.getClass().getSimpleName() + "], attempted to use" + ex.getMessage().substring(ex.getMessage().lastIndexOf(' ')));
|
"Failed to load due to a [" + ex.getClass().getSimpleName() + "], attempted to use" + ex
|
||||||
|
.getMessage().substring(ex.getMessage().lastIndexOf(' ')));
|
||||||
return null;
|
return null;
|
||||||
}
|
} catch (final Exception ex) {
|
||||||
catch (final Exception ex)
|
|
||||||
{
|
|
||||||
throw new CompletionException(ex);
|
throw new CompletionException(ex);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -367,32 +328,27 @@ public final class LocalExpansionManager implements Listener
|
|||||||
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public PlaceholderExpansion createExpansionInstance(@NotNull final Class<? extends PlaceholderExpansion> clazz) throws LinkageError
|
public PlaceholderExpansion createExpansionInstance(
|
||||||
{
|
@NotNull final Class<? extends PlaceholderExpansion> clazz) throws LinkageError {
|
||||||
try
|
try {
|
||||||
{
|
|
||||||
return clazz.getDeclaredConstructor().newInstance();
|
return clazz.getDeclaredConstructor().newInstance();
|
||||||
}
|
} catch (final Exception ex) {
|
||||||
catch (final Exception ex)
|
if (ex.getCause() instanceof LinkageError) {
|
||||||
{
|
|
||||||
if (ex.getCause() instanceof LinkageError)
|
|
||||||
{
|
|
||||||
throw ((LinkageError) ex.getCause());
|
throw ((LinkageError) ex.getCause());
|
||||||
}
|
}
|
||||||
|
|
||||||
plugin.getLogger().log(Level.SEVERE, "Failed to load placeholder expansion from class: " + clazz.getName(), ex);
|
plugin.getLogger()
|
||||||
|
.log(Level.SEVERE, "Failed to load placeholder expansion from class: " + clazz.getName(),
|
||||||
|
ex);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onQuit(@NotNull final PlayerQuitEvent event)
|
public void onQuit(@NotNull final PlayerQuitEvent event) {
|
||||||
{
|
for (final PlaceholderExpansion expansion : getExpansions()) {
|
||||||
for (final PlaceholderExpansion expansion : getExpansions())
|
if (!(expansion instanceof Cleanable)) {
|
||||||
{
|
|
||||||
if (!(expansion instanceof Cleanable))
|
|
||||||
{
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -401,18 +357,14 @@ public final class LocalExpansionManager implements Listener
|
|||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGH)
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
public void onPluginDisable(@NotNull final PluginDisableEvent event)
|
public void onPluginDisable(@NotNull final PluginDisableEvent event) {
|
||||||
{
|
|
||||||
final String name = event.getPlugin().getName();
|
final String name = event.getPlugin().getName();
|
||||||
if (name.equals(plugin.getName()))
|
if (name.equals(plugin.getName())) {
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (final PlaceholderExpansion expansion : getExpansions())
|
for (final PlaceholderExpansion expansion : getExpansions()) {
|
||||||
{
|
if (!name.equalsIgnoreCase(expansion.getRequiredPlugin())) {
|
||||||
if (!name.equalsIgnoreCase(expansion.getRequiredPlugin()))
|
|
||||||
{
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,11 +17,6 @@ import com.google.gson.JsonArray;
|
|||||||
import com.google.gson.JsonElement;
|
import com.google.gson.JsonElement;
|
||||||
import com.google.gson.JsonObject;
|
import com.google.gson.JsonObject;
|
||||||
import com.google.gson.JsonPrimitive;
|
import com.google.gson.JsonPrimitive;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.ChatColor;
|
|
||||||
import org.bukkit.entity.Player;
|
|
||||||
|
|
||||||
import java.lang.invoke.MethodHandle;
|
import java.lang.invoke.MethodHandle;
|
||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
import java.lang.reflect.Constructor;
|
import java.lang.reflect.Constructor;
|
||||||
@ -32,15 +27,19 @@ import java.util.List;
|
|||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import java.util.Vector;
|
import java.util.Vector;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is a complete JSON message builder class. To create a new JSONMessage do
|
* This is a complete JSON message builder class. To create a new JSONMessage do {@link
|
||||||
* {@link #create(String)}
|
* #create(String)}
|
||||||
*
|
*
|
||||||
* @author Rayzr
|
* @author Rayzr
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings({"WeakerAccess", "unused"})
|
@SuppressWarnings({"WeakerAccess", "unused"})
|
||||||
public class JSONMessage {
|
public class JSONMessage {
|
||||||
|
|
||||||
private static final BiMap<ChatColor, String> stylesToNames;
|
private static final BiMap<ChatColor, String> stylesToNames;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
@ -107,7 +106,8 @@ public class JSONMessage {
|
|||||||
* @param players The players you want to send it to
|
* @param players The players you want to send it to
|
||||||
*/
|
*/
|
||||||
public static void actionbar(String message, Player... players) {
|
public static void actionbar(String message, Player... players) {
|
||||||
ReflectionHelper.sendPacket(ReflectionHelper.createActionbarPacket(ChatColor.translateAlternateColorCodes('&', message)), players);
|
ReflectionHelper.sendPacket(ReflectionHelper
|
||||||
|
.createActionbarPacket(ChatColor.translateAlternateColorCodes('&', message)), players);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -143,8 +143,8 @@ public class JSONMessage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts this {@link JSONMessage} object to a String representation of the JSON.
|
* Converts this {@link JSONMessage} object to a String representation of the JSON. This is an
|
||||||
* This is an alias of {@code toJSON().toString()}.
|
* alias of {@code toJSON().toString()}.
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
@ -152,8 +152,8 @@ public class JSONMessage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts this {@link JSONMessage} object to the legacy formatting system, which
|
* Converts this {@link JSONMessage} object to the legacy formatting system, which uses formatting
|
||||||
* uses formatting codes (like &6, &l, &4, etc.)
|
* codes (like &6, &l, &4, etc.)
|
||||||
*
|
*
|
||||||
* @return This {@link JSONMessage} instance {@link JSONMessage} in legacy format
|
* @return This {@link JSONMessage} instance {@link JSONMessage} in legacy format
|
||||||
*/
|
*/
|
||||||
@ -190,12 +190,14 @@ public class JSONMessage {
|
|||||||
* @param players The players to send this to
|
* @param players The players to send this to
|
||||||
*/
|
*/
|
||||||
public void title(int fadeIn, int stay, int fadeOut, Player... players) {
|
public void title(int fadeIn, int stay, int fadeOut, Player... players) {
|
||||||
ReflectionHelper.sendPacket(ReflectionHelper.createTitleTimesPacket(fadeIn, stay, fadeOut), players);
|
ReflectionHelper
|
||||||
|
.sendPacket(ReflectionHelper.createTitleTimesPacket(fadeIn, stay, fadeOut), players);
|
||||||
ReflectionHelper.sendPacket(ReflectionHelper.createTitlePacket(toString()), players);
|
ReflectionHelper.sendPacket(ReflectionHelper.createTitlePacket(toString()), players);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sends this as a subtitle to all the players specified. Must be used after sending a {@link #title(int, int, int, Player...) title}.
|
* Sends this as a subtitle to all the players specified. Must be used after sending a {@link
|
||||||
|
* #title(int, int, int, Player...) title}.
|
||||||
*
|
*
|
||||||
* @param players The players to send this to
|
* @param players The players to send this to
|
||||||
*/
|
*/
|
||||||
@ -219,8 +221,9 @@ public class JSONMessage {
|
|||||||
* @return This {@link JSONMessage} instance
|
* @return This {@link JSONMessage} instance
|
||||||
*/
|
*/
|
||||||
public JSONMessage color(ChatColor color) {
|
public JSONMessage color(ChatColor color) {
|
||||||
if (!color.isColor())
|
if (!color.isColor()) {
|
||||||
throw new IllegalArgumentException(color.name() + " is not a color.");
|
throw new IllegalArgumentException(color.name() + " is not a color.");
|
||||||
|
}
|
||||||
|
|
||||||
last().setColor(color);
|
last().setColor(color);
|
||||||
return this;
|
return this;
|
||||||
@ -228,7 +231,8 @@ public class JSONMessage {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the color of the current message part.
|
* Sets the color of the current message part.
|
||||||
* <br>If the provided color is a hex color ({@code #rrggbb}) but the major version of MC is older than 1.16 will this
|
* <br>If the provided color is a hex color ({@code #rrggbb}) but the major version of MC is older
|
||||||
|
* than 1.16 will this
|
||||||
* default to the color WHITE.
|
* default to the color WHITE.
|
||||||
*
|
*
|
||||||
* @param color The color to set
|
* @param color The color to set
|
||||||
@ -240,7 +244,8 @@ public class JSONMessage {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the color of the current message part.
|
* Sets the color of the current message part.
|
||||||
* <br>If the provided color is a hex color ({@code #rrggbb}) but the major version of MC is older than 1.16 will the provided
|
* <br>If the provided color is a hex color ({@code #rrggbb}) but the major version of MC is older
|
||||||
|
* than 1.16 will the provided
|
||||||
* default ChatColor be used instead.
|
* default ChatColor be used instead.
|
||||||
*
|
*
|
||||||
* @param color The color to set
|
* @param color The color to set
|
||||||
@ -248,8 +253,9 @@ public class JSONMessage {
|
|||||||
* @return This {@link JSONMessage} instance
|
* @return This {@link JSONMessage} instance
|
||||||
*/
|
*/
|
||||||
public JSONMessage color(String color, ChatColor def) {
|
public JSONMessage color(String color, ChatColor def) {
|
||||||
if (color.startsWith("#") && ReflectionHelper.MAJOR_VER < 16)
|
if (color.startsWith("#") && ReflectionHelper.MAJOR_VER < 16) {
|
||||||
return color(def);
|
return color(def);
|
||||||
|
}
|
||||||
|
|
||||||
last().setColor(color);
|
last().setColor(color);
|
||||||
return this;
|
return this;
|
||||||
@ -263,8 +269,9 @@ public class JSONMessage {
|
|||||||
* @return This {@link JSONMessage} instance
|
* @return This {@link JSONMessage} instance
|
||||||
*/
|
*/
|
||||||
public JSONMessage font(String font) {
|
public JSONMessage font(String font) {
|
||||||
if (ReflectionHelper.MAJOR_VER < 16)
|
if (ReflectionHelper.MAJOR_VER < 16) {
|
||||||
return this;
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
last().setFont(font);
|
last().setFont(font);
|
||||||
return this;
|
return this;
|
||||||
@ -316,7 +323,8 @@ public class JSONMessage {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Copies the provided text to the Clipboard of the player.
|
* Copies the provided text to the Clipboard of the player.
|
||||||
* <br>When this is used on versions older than 1.15 will this default to {@link #suggestCommand(String) suggestCommand(String)}.
|
* <br>When this is used on versions older than 1.15 will this default to {@link
|
||||||
|
* #suggestCommand(String) suggestCommand(String)}.
|
||||||
*
|
*
|
||||||
* @param text The text to copy
|
* @param text The text to copy
|
||||||
* @return This {@link JSONMessage} instance
|
* @return This {@link JSONMessage} instance
|
||||||
@ -327,8 +335,8 @@ public class JSONMessage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Changes the page of a book. Using this in a non-book context is useless
|
* Changes the page of a book. Using this in a non-book context is useless and will probably
|
||||||
* and will probably error.
|
* error.
|
||||||
*
|
*
|
||||||
* @param page The page to change to
|
* @param page The page to change to
|
||||||
* @return This {@link JSONMessage} instance
|
* @return This {@link JSONMessage} instance
|
||||||
@ -399,12 +407,13 @@ public class JSONMessage {
|
|||||||
* @return This {@link JSONMessage} instance
|
* @return This {@link JSONMessage} instance
|
||||||
*/
|
*/
|
||||||
public JSONMessage bar(int length) {
|
public JSONMessage bar(int length) {
|
||||||
return then(Strings.repeat("-", length)).color(ChatColor.DARK_GRAY).style(ChatColor.STRIKETHROUGH);
|
return then(Strings.repeat("-", length)).color(ChatColor.DARK_GRAY)
|
||||||
|
.style(ChatColor.STRIKETHROUGH);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a horizontal bar to the message that's 53 characters long. This is
|
* Adds a horizontal bar to the message that's 53 characters long. This is the default width of
|
||||||
* the default width of the player's chat window.
|
* the player's chat window.
|
||||||
*
|
*
|
||||||
* @return This {@link JSONMessage} instance
|
* @return This {@link JSONMessage} instance
|
||||||
*/
|
*/
|
||||||
@ -451,7 +460,8 @@ public class JSONMessage {
|
|||||||
|
|
||||||
if (current >= parts.size() || totalLineLength + rawLength >= 53) {
|
if (current >= parts.size() || totalLineLength + rawLength >= 53) {
|
||||||
int padding = Math.max(0, (53 - totalLineLength) / 2);
|
int padding = Math.max(0, (53 - totalLineLength) / 2);
|
||||||
currentLine.firstElement().setText(Strings.repeat(" ", padding) + currentLine.firstElement().getText());
|
currentLine.firstElement()
|
||||||
|
.setText(Strings.repeat(" ", padding) + currentLine.firstElement().getText());
|
||||||
currentLine.lastElement().setText(currentLine.lastElement().getText() + "\n");
|
currentLine.lastElement().setText(currentLine.lastElement().getText() + "\n");
|
||||||
currentLine.clear();
|
currentLine.clear();
|
||||||
break;
|
break;
|
||||||
@ -502,7 +512,8 @@ public class JSONMessage {
|
|||||||
* MC 1.16 changed "value" to "contents", but only for Hover events... Don't ask why.
|
* MC 1.16 changed "value" to "contents", but only for Hover events... Don't ask why.
|
||||||
* Since this lib only has tooltip and achievement can we simply check if action starts with "show_"
|
* Since this lib only has tooltip and achievement can we simply check if action starts with "show_"
|
||||||
*/
|
*/
|
||||||
String valueType = (ReflectionHelper.MAJOR_VER >= 16 && action.startsWith("show_")) ? "contents" : "value";
|
String valueType =
|
||||||
|
(ReflectionHelper.MAJOR_VER >= 16 && action.startsWith("show_")) ? "contents" : "value";
|
||||||
|
|
||||||
if (value instanceof JsonElement) {
|
if (value instanceof JsonElement) {
|
||||||
obj.add(valueType, (JsonElement) value);
|
obj.add(valueType, (JsonElement) value);
|
||||||
@ -586,14 +597,16 @@ public class JSONMessage {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Copies the provided text to the clipboard of the player.
|
* Copies the provided text to the clipboard of the player.
|
||||||
* <br>When used on versions older than 1.15 will this {@link #suggestCommand(String) suggest the text} instead.
|
* <br>When used on versions older than 1.15 will this {@link #suggestCommand(String) suggest
|
||||||
|
* the text} instead.
|
||||||
*
|
*
|
||||||
* @param text The text to copy.
|
* @param text The text to copy.
|
||||||
* @return The {@link MessageEvent}
|
* @return The {@link MessageEvent}
|
||||||
*/
|
*/
|
||||||
public static MessageEvent copyText(String text) {
|
public static MessageEvent copyText(String text) {
|
||||||
if (ReflectionHelper.MAJOR_VER < 15)
|
if (ReflectionHelper.MAJOR_VER < 15) {
|
||||||
return suggestCommand(text);
|
return suggestCommand(text);
|
||||||
|
}
|
||||||
|
|
||||||
return new MessageEvent("copy_to_clipboard", text);
|
return new MessageEvent("copy_to_clipboard", text);
|
||||||
}
|
}
|
||||||
@ -682,7 +695,8 @@ public class JSONMessage {
|
|||||||
if (MAJOR_VER < 8) {
|
if (MAJOR_VER < 8) {
|
||||||
stringToChat = getClass("{nms}.ChatSerializer").getMethod("a", String.class);
|
stringToChat = getClass("{nms}.ChatSerializer").getMethod("a", String.class);
|
||||||
} else {
|
} else {
|
||||||
stringToChat = getClass("{nms}.IChatBaseComponent$ChatSerializer").getMethod("a", String.class);
|
stringToChat = getClass("{nms}.IChatBaseComponent$ChatSerializer")
|
||||||
|
.getMethod("a", String.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
GET_HANDLE = MethodHandles.lookup().unreflect(getHandle);
|
GET_HANDLE = MethodHandles.lookup().unreflect(getHandle);
|
||||||
@ -698,7 +712,8 @@ public class JSONMessage {
|
|||||||
Class<?> titleAction = getClass("{nms}.PacketPlayOutTitle$EnumTitleAction");
|
Class<?> titleAction = getClass("{nms}.PacketPlayOutTitle$EnumTitleAction");
|
||||||
|
|
||||||
titlePacketConstructor = packetPlayOutTitle.getConstructor(titleAction, iChatBaseComponent);
|
titlePacketConstructor = packetPlayOutTitle.getConstructor(titleAction, iChatBaseComponent);
|
||||||
titleTimesPacketConstructor = packetPlayOutTitle.getConstructor(int.class, int.class, int.class);
|
titleTimesPacketConstructor = packetPlayOutTitle
|
||||||
|
.getConstructor(int.class, int.class, int.class);
|
||||||
|
|
||||||
enumActionTitle = titleAction.getField("TITLE").get(null);
|
enumActionTitle = titleAction.getField("TITLE").get(null);
|
||||||
enumActionSubtitle = titleAction.getField("SUBTITLE").get(null);
|
enumActionSubtitle = titleAction.getField("SUBTITLE").get(null);
|
||||||
@ -833,7 +848,8 @@ public class JSONMessage {
|
|||||||
* Attempts to convert a String representing a JSON message into a usable object
|
* Attempts to convert a String representing a JSON message into a usable object
|
||||||
*
|
*
|
||||||
* @param json The JSON to attempt to parse
|
* @param json The JSON to attempt to parse
|
||||||
* @return The object representing the text in JSON form, or <code>null</code> if something went wrong converting the String to JSON data
|
* @return The object representing the text in JSON form, or <code>null</code> if something went
|
||||||
|
* wrong converting the String to JSON data
|
||||||
*/
|
*/
|
||||||
static Object fromJson(String json) {
|
static Object fromJson(String json) {
|
||||||
assertIsSetup();
|
assertIsSetup();
|
||||||
@ -857,7 +873,8 @@ public class JSONMessage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static Class<?> getClass(String path) throws ClassNotFoundException {
|
private static Class<?> getClass(String path) throws ClassNotFoundException {
|
||||||
return Class.forName(path.replace("{nms}", "net.minecraft.server." + version).replace("{obc}", "org.bukkit.craftbukkit." + version));
|
return Class.forName(path.replace("{nms}", "net.minecraft.server." + version)
|
||||||
|
.replace("{obc}", "org.bukkit.craftbukkit." + version));
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void setFieldValue(Field field, Object instance, Object value) {
|
private static void setFieldValue(Field field, Object instance, Object value) {
|
||||||
@ -890,7 +907,8 @@ public class JSONMessage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines a section of the message, and represents the format that all JSON messages must follow in Minecraft.
|
* Defines a section of the message, and represents the format that all JSON messages must follow
|
||||||
|
* in Minecraft.
|
||||||
* <br>
|
* <br>
|
||||||
* <br>
|
* <br>
|
||||||
* <a href="http://minecraft.gamepedia.com/Commands#Raw_JSON_text">Reference</a>
|
* <a href="http://minecraft.gamepedia.com/Commands#Raw_JSON_text">Reference</a>
|
||||||
@ -1009,8 +1027,10 @@ public class JSONMessage {
|
|||||||
return legacyColor;
|
return legacyColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.color.startsWith("#") && ReflectionHelper.MAJOR_VER < 16)
|
if (this.color.startsWith("#") && ReflectionHelper.MAJOR_VER < 16) {
|
||||||
throw new IllegalStateException("Custom Hex colors can only be used in Minecraft 1.16 or newer!");
|
throw new IllegalStateException(
|
||||||
|
"Custom Hex colors can only be used in Minecraft 1.16 or newer!");
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return ChatColor.valueOf(this.color.toUpperCase());
|
return ChatColor.valueOf(this.color.toUpperCase());
|
||||||
@ -1029,15 +1049,6 @@ public class JSONMessage {
|
|||||||
setLegacyColor(color);
|
setLegacyColor(color);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @param color The legacy ChatColor to set
|
|
||||||
* @deprecated Use {@link #setColor(String)} instead
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public void setLegacyColor(ChatColor color) {
|
|
||||||
legacyColor = color;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param color The color to set
|
* @param color The color to set
|
||||||
*/
|
*/
|
||||||
@ -1048,6 +1059,15 @@ public class JSONMessage {
|
|||||||
this.color = color;
|
this.color = color;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param color The legacy ChatColor to set
|
||||||
|
* @deprecated Use {@link #setColor(String)} instead
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public void setLegacyColor(ChatColor color) {
|
||||||
|
legacyColor = color;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return The list of styles
|
* @return The list of styles
|
||||||
*/
|
*/
|
||||||
|
@ -28,14 +28,12 @@ import org.bukkit.event.Listener;
|
|||||||
import org.bukkit.event.server.ServerLoadEvent;
|
import org.bukkit.event.server.ServerLoadEvent;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public final class ServerLoadEventListener implements Listener
|
public final class ServerLoadEventListener implements Listener {
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final PlaceholderAPIPlugin plugin;
|
private final PlaceholderAPIPlugin plugin;
|
||||||
|
|
||||||
public ServerLoadEventListener(@NotNull final PlaceholderAPIPlugin plugin)
|
public ServerLoadEventListener(@NotNull final PlaceholderAPIPlugin plugin) {
|
||||||
{
|
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
|
|
||||||
Bukkit.getPluginManager().registerEvents(this, plugin);
|
Bukkit.getPluginManager().registerEvents(this, plugin);
|
||||||
@ -44,16 +42,15 @@ public final class ServerLoadEventListener implements Listener
|
|||||||
/**
|
/**
|
||||||
* This method will be called when the server is first loaded
|
* This method will be called when the server is first loaded
|
||||||
* <p>
|
* <p>
|
||||||
* The goal of the method is to register all the expansions as soon as possible
|
* The goal of the method is to register all the expansions as soon as possible especially before
|
||||||
* especially before players can join
|
* players can join
|
||||||
* <p>
|
* <p>
|
||||||
* This will ensure no issues with expansions and hooks.
|
* This will ensure no issues with expansions and hooks.
|
||||||
*
|
*
|
||||||
* @param event the server load event
|
* @param event the server load event
|
||||||
*/
|
*/
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onServerLoad(@NotNull final ServerLoadEvent event)
|
public void onServerLoad(@NotNull final ServerLoadEvent event) {
|
||||||
{
|
|
||||||
HandlerList.unregisterAll(this);
|
HandlerList.unregisterAll(this);
|
||||||
plugin.getLocalExpansionManager().load(Bukkit.getConsoleSender());
|
plugin.getLocalExpansionManager().load(Bukkit.getConsoleSender());
|
||||||
}
|
}
|
||||||
|
@ -20,60 +20,53 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.replacer;
|
package me.clip.placeholderapi.replacer;
|
||||||
|
|
||||||
|
import java.util.function.Function;
|
||||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.OfflinePlayer;
|
import org.bukkit.OfflinePlayer;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.util.function.Function;
|
public final class CharsReplacer implements Replacer {
|
||||||
|
|
||||||
public final class CharsReplacer implements Replacer
|
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final Closure closure;
|
private final Closure closure;
|
||||||
|
|
||||||
public CharsReplacer(@NotNull final Closure closure)
|
public CharsReplacer(@NotNull final Closure closure) {
|
||||||
{
|
|
||||||
this.closure = closure;
|
this.closure = closure;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Override
|
@Override
|
||||||
public String apply(@NotNull final String text, @Nullable final OfflinePlayer player, @NotNull final Function<String, @Nullable PlaceholderExpansion> lookup)
|
public String apply(@NotNull final String text, @Nullable final OfflinePlayer player,
|
||||||
{
|
@NotNull final Function<String, @Nullable PlaceholderExpansion> lookup) {
|
||||||
final char[] chars = text.toCharArray();
|
final char[] chars = text.toCharArray();
|
||||||
final StringBuilder builder = new StringBuilder(text.length());
|
final StringBuilder builder = new StringBuilder(text.length());
|
||||||
|
|
||||||
final StringBuilder identifier = new StringBuilder();
|
final StringBuilder identifier = new StringBuilder();
|
||||||
final StringBuilder parameters = new StringBuilder();
|
final StringBuilder parameters = new StringBuilder();
|
||||||
|
|
||||||
for (int i = 0; i < chars.length; i++)
|
for (int i = 0; i < chars.length; i++) {
|
||||||
{
|
|
||||||
final char l = chars[i];
|
final char l = chars[i];
|
||||||
|
|
||||||
if (l == '&' && ++i < chars.length)
|
if (l == '&' && ++i < chars.length) {
|
||||||
{
|
|
||||||
final char c = Character.toLowerCase(chars[i]);
|
final char c = Character.toLowerCase(chars[i]);
|
||||||
|
|
||||||
if (c != '0' && c != '1' && c != '2' && c != '3' && c != '4' && c != '5' && c != '6' && c != '7' && c != '8' && c != '9' && c != 'a' && c != 'b' && c != 'c' && c != 'd' && c != 'e' && c != 'f' && c != 'k' && c != 'l' && c != 'm' && c != 'o' && c != 'r' && c != 'x')
|
if (c != '0' && c != '1' && c != '2' && c != '3' && c != '4' && c != '5' && c != '6'
|
||||||
{
|
&& c != '7' && c != '8' && c != '9' && c != 'a' && c != 'b' && c != 'c' && c != 'd'
|
||||||
|
&& c != 'e' && c != 'f' && c != 'k' && c != 'l' && c != 'm' && c != 'o' && c != 'r'
|
||||||
|
&& c != 'x') {
|
||||||
builder.append(l).append(chars[i]);
|
builder.append(l).append(chars[i]);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
builder.append(ChatColor.COLOR_CHAR);
|
builder.append(ChatColor.COLOR_CHAR);
|
||||||
|
|
||||||
if (c != 'x')
|
if (c != 'x') {
|
||||||
{
|
|
||||||
builder.append(chars[i]);
|
builder.append(chars[i]);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((i > 1 && chars[i - 2] == '\\') /*allow escaping &x*/)
|
if ((i > 1 && chars[i - 2] == '\\') /*allow escaping &x*/) {
|
||||||
{
|
|
||||||
builder.setLength(builder.length() - 2);
|
builder.setLength(builder.length() - 2);
|
||||||
builder.append('&').append(chars[i]);
|
builder.append('&').append(chars[i]);
|
||||||
continue;
|
continue;
|
||||||
@ -82,10 +75,8 @@ public final class CharsReplacer implements Replacer
|
|||||||
builder.append(c);
|
builder.append(c);
|
||||||
|
|
||||||
int j = 0;
|
int j = 0;
|
||||||
while (++j <= 6)
|
while (++j <= 6) {
|
||||||
{
|
if (i + j >= chars.length) {
|
||||||
if (i + j >= chars.length)
|
|
||||||
{
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -93,20 +84,16 @@ public final class CharsReplacer implements Replacer
|
|||||||
builder.append(ChatColor.COLOR_CHAR).append(x);
|
builder.append(ChatColor.COLOR_CHAR).append(x);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (j == 7)
|
if (j == 7) {
|
||||||
{
|
|
||||||
i += 6;
|
i += 6;
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
builder.setLength(builder.length() - (j * 2)); // undo &x parsing
|
builder.setLength(builder.length() - (j * 2)); // undo &x parsing
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (l != closure.head || i + 1 >= chars.length)
|
if (l != closure.head || i + 1 >= chars.length) {
|
||||||
{
|
|
||||||
builder.append(l);
|
builder.append(l);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -114,32 +101,25 @@ public final class CharsReplacer implements Replacer
|
|||||||
boolean identified = false;
|
boolean identified = false;
|
||||||
boolean oopsitsbad = true;
|
boolean oopsitsbad = true;
|
||||||
|
|
||||||
while (++i < chars.length)
|
while (++i < chars.length) {
|
||||||
{
|
|
||||||
final char p = chars[i];
|
final char p = chars[i];
|
||||||
|
|
||||||
if (p == ' ' && !identified)
|
if (p == ' ' && !identified) {
|
||||||
{
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (p == closure.tail)
|
if (p == closure.tail) {
|
||||||
{
|
|
||||||
oopsitsbad = false;
|
oopsitsbad = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p == '_' && !identified)
|
if (p == '_' && !identified) {
|
||||||
{
|
|
||||||
identified = true;
|
identified = true;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (identified)
|
if (identified) {
|
||||||
{
|
|
||||||
parameters.append(p);
|
parameters.append(p);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
identifier.append(p);
|
identifier.append(p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -150,12 +130,10 @@ public final class CharsReplacer implements Replacer
|
|||||||
identifier.setLength(0);
|
identifier.setLength(0);
|
||||||
parameters.setLength(0);
|
parameters.setLength(0);
|
||||||
|
|
||||||
if (oopsitsbad)
|
if (oopsitsbad) {
|
||||||
{
|
|
||||||
builder.append(closure.head).append(identifierString);
|
builder.append(closure.head).append(identifierString);
|
||||||
|
|
||||||
if (identified)
|
if (identified) {
|
||||||
{
|
|
||||||
builder.append('_').append(parametersString);
|
builder.append('_').append(parametersString);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -164,12 +142,10 @@ public final class CharsReplacer implements Replacer
|
|||||||
}
|
}
|
||||||
|
|
||||||
final PlaceholderExpansion placeholder = lookup.apply(identifierString);
|
final PlaceholderExpansion placeholder = lookup.apply(identifierString);
|
||||||
if (placeholder == null)
|
if (placeholder == null) {
|
||||||
{
|
|
||||||
builder.append(closure.head).append(identifierString);
|
builder.append(closure.head).append(identifierString);
|
||||||
|
|
||||||
if (identified)
|
if (identified) {
|
||||||
{
|
|
||||||
builder.append('_');
|
builder.append('_');
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -178,12 +154,10 @@ public final class CharsReplacer implements Replacer
|
|||||||
}
|
}
|
||||||
|
|
||||||
final String replacement = placeholder.onRequest(player, parametersString);
|
final String replacement = placeholder.onRequest(player, parametersString);
|
||||||
if (replacement == null)
|
if (replacement == null) {
|
||||||
{
|
|
||||||
builder.append(closure.head).append(identifierString);
|
builder.append(closure.head).append(identifierString);
|
||||||
|
|
||||||
if (identified)
|
if (identified) {
|
||||||
{
|
|
||||||
builder.append('_');
|
builder.append('_');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,48 +20,44 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.replacer;
|
package me.clip.placeholderapi.replacer;
|
||||||
|
|
||||||
|
import java.util.function.Function;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.OfflinePlayer;
|
import org.bukkit.OfflinePlayer;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.util.function.Function;
|
public final class RegexReplacer implements Replacer {
|
||||||
import java.util.regex.Matcher;
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
public final class RegexReplacer implements Replacer
|
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final Pattern pattern;
|
private final Pattern pattern;
|
||||||
|
|
||||||
public RegexReplacer(@NotNull final Closure closure)
|
public RegexReplacer(@NotNull final Closure closure) {
|
||||||
{
|
this.pattern = Pattern.compile(String
|
||||||
this.pattern = Pattern.compile(String.format("\\%s((?<identifier>[a-zA-Z0-9]+)_)(?<parameters>[^%s%s]+)\\%s", closure.head, closure.head, closure.tail, closure.tail));
|
.format("\\%s((?<identifier>[a-zA-Z0-9]+)_)(?<parameters>[^%s%s]+)\\%s", closure.head,
|
||||||
|
closure.head, closure.tail, closure.tail));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Override
|
@Override
|
||||||
public String apply(@NotNull final String text, @Nullable final OfflinePlayer player, @NotNull final Function<String, @Nullable PlaceholderExpansion> lookup)
|
public String apply(@NotNull final String text, @Nullable final OfflinePlayer player,
|
||||||
{
|
@NotNull final Function<String, @Nullable PlaceholderExpansion> lookup) {
|
||||||
final Matcher matcher = pattern.matcher(text);
|
final Matcher matcher = pattern.matcher(text);
|
||||||
if (!matcher.find())
|
if (!matcher.find()) {
|
||||||
{
|
|
||||||
return text;
|
return text;
|
||||||
}
|
}
|
||||||
|
|
||||||
final StringBuffer builder = new StringBuffer();
|
final StringBuffer builder = new StringBuffer();
|
||||||
|
|
||||||
do
|
do {
|
||||||
{
|
|
||||||
final String identifier = matcher.group("identifier");
|
final String identifier = matcher.group("identifier");
|
||||||
final String parameters = matcher.group("parameters");
|
final String parameters = matcher.group("parameters");
|
||||||
|
|
||||||
final PlaceholderExpansion expansion = lookup.apply(identifier);
|
final PlaceholderExpansion expansion = lookup.apply(identifier);
|
||||||
if (expansion == null)
|
if (expansion == null) {
|
||||||
{
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,30 +20,27 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.replacer;
|
package me.clip.placeholderapi.replacer;
|
||||||
|
|
||||||
|
import java.util.function.Function;
|
||||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
|
||||||
import org.bukkit.OfflinePlayer;
|
import org.bukkit.OfflinePlayer;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.util.function.Function;
|
public interface Replacer {
|
||||||
|
|
||||||
public interface Replacer
|
|
||||||
{
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
String apply(@NotNull final String text, @Nullable final OfflinePlayer player, @NotNull final Function<String, @Nullable PlaceholderExpansion> lookup);
|
String apply(@NotNull final String text, @Nullable final OfflinePlayer player,
|
||||||
|
@NotNull final Function<String, @Nullable PlaceholderExpansion> lookup);
|
||||||
|
|
||||||
|
|
||||||
enum Closure
|
enum Closure {
|
||||||
{
|
|
||||||
BRACKET('{', '}'),
|
BRACKET('{', '}'),
|
||||||
PERCENT('%', '%');
|
PERCENT('%', '%');
|
||||||
|
|
||||||
|
|
||||||
public final char head, tail;
|
public final char head, tail;
|
||||||
|
|
||||||
Closure(final char head, final char tail)
|
Closure(final char head, final char tail) {
|
||||||
{
|
|
||||||
this.head = head;
|
this.head = head;
|
||||||
this.tail = tail;
|
this.tail = tail;
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,10 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.updatechecker;
|
package me.clip.placeholderapi.updatechecker;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.net.URL;
|
||||||
|
import javax.net.ssl.HttpsURLConnection;
|
||||||
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
import me.clip.placeholderapi.PlaceholderAPIPlugin;
|
||||||
import me.clip.placeholderapi.util.Msg;
|
import me.clip.placeholderapi.util.Msg;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
@ -28,11 +32,6 @@ import org.bukkit.event.EventPriority;
|
|||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.player.PlayerJoinEvent;
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
|
||||||
import javax.net.ssl.HttpsURLConnection;
|
|
||||||
import java.io.BufferedReader;
|
|
||||||
import java.io.InputStreamReader;
|
|
||||||
import java.net.URL;
|
|
||||||
|
|
||||||
public class UpdateChecker implements Listener {
|
public class UpdateChecker implements Listener {
|
||||||
|
|
||||||
private final int RESOURCE_ID = 6245;
|
private final int RESOURCE_ID = 6245;
|
||||||
|
@ -20,9 +20,6 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.util;
|
package me.clip.placeholderapi.util;
|
||||||
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
import org.jetbrains.annotations.Nullable;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
@ -31,15 +28,15 @@ import java.util.ArrayList;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.jar.JarEntry;
|
import java.util.jar.JarEntry;
|
||||||
import java.util.jar.JarInputStream;
|
import java.util.jar.JarInputStream;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
public class FileUtil
|
public class FileUtil {
|
||||||
{
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public static <T> Class<? extends T> findClass(@NotNull final File file, @NotNull final Class<T> clazz) throws IOException, ClassNotFoundException
|
public static <T> Class<? extends T> findClass(@NotNull final File file,
|
||||||
{
|
@NotNull final Class<T> clazz) throws IOException, ClassNotFoundException {
|
||||||
if (!file.exists())
|
if (!file.exists()) {
|
||||||
{
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -48,33 +45,27 @@ public class FileUtil
|
|||||||
final List<String> matches = new ArrayList<>();
|
final List<String> matches = new ArrayList<>();
|
||||||
final List<Class<? extends T>> classes = new ArrayList<>();
|
final List<Class<? extends T>> classes = new ArrayList<>();
|
||||||
|
|
||||||
|
try (final JarInputStream stream = new JarInputStream(
|
||||||
try (final JarInputStream stream = new JarInputStream(jar.openStream()); final URLClassLoader loader = new URLClassLoader(new URL[]{jar}, clazz.getClassLoader()))
|
jar.openStream()); final URLClassLoader loader = new URLClassLoader(new URL[]{jar},
|
||||||
{
|
clazz.getClassLoader())) {
|
||||||
JarEntry entry;
|
JarEntry entry;
|
||||||
while ((entry = stream.getNextJarEntry()) != null)
|
while ((entry = stream.getNextJarEntry()) != null) {
|
||||||
{
|
|
||||||
final String name = entry.getName();
|
final String name = entry.getName();
|
||||||
if (name == null || name.isEmpty() || !name.endsWith(".class"))
|
if (name == null || name.isEmpty() || !name.endsWith(".class")) {
|
||||||
{
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
matches.add(name.substring(0, name.lastIndexOf('.')).replace('/', '.'));
|
matches.add(name.substring(0, name.lastIndexOf('.')).replace('/', '.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
for (final String match : matches)
|
for (final String match : matches) {
|
||||||
{
|
try {
|
||||||
try
|
|
||||||
{
|
|
||||||
final Class<?> loaded = loader.loadClass(match);
|
final Class<?> loaded = loader.loadClass(match);
|
||||||
if (clazz.isAssignableFrom(loaded))
|
if (clazz.isAssignableFrom(loaded)) {
|
||||||
{
|
|
||||||
classes.add(loaded.asSubclass(clazz));
|
classes.add(loaded.asSubclass(clazz));
|
||||||
}
|
}
|
||||||
|
} catch (final NoClassDefFoundError ignored) {
|
||||||
}
|
}
|
||||||
catch (final NoClassDefFoundError ignored)
|
|
||||||
{ }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,11 +20,6 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.util;
|
package me.clip.placeholderapi.util;
|
||||||
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Optional;
|
|
||||||
|
|
||||||
import static java.lang.Math.max;
|
import static java.lang.Math.max;
|
||||||
import static java.lang.Math.min;
|
import static java.lang.Math.min;
|
||||||
import static java.util.Arrays.stream;
|
import static java.util.Arrays.stream;
|
||||||
@ -32,47 +27,44 @@ import static java.util.stream.Collectors.joining;
|
|||||||
import static java.util.stream.Collectors.toList;
|
import static java.util.stream.Collectors.toList;
|
||||||
import static java.util.stream.IntStream.range;
|
import static java.util.stream.IntStream.range;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* For the record, I am not sorry.
|
* For the record, I am not sorry.
|
||||||
*/
|
*/
|
||||||
public final class Format
|
public final class Format {
|
||||||
{
|
|
||||||
|
|
||||||
private Format()
|
|
||||||
{}
|
|
||||||
|
|
||||||
|
|
||||||
public enum Align
|
|
||||||
{
|
|
||||||
LEFT, RIGHT
|
|
||||||
}
|
|
||||||
|
|
||||||
|
private Format() {}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public static Optional<List<String>> tablify(@NotNull final Align align, @NotNull final List<List<String>> rows)
|
public static Optional<List<String>> tablify(@NotNull final Align align,
|
||||||
{
|
@NotNull final List<List<String>> rows) {
|
||||||
return findSpacing(rows)
|
return findSpacing(rows)
|
||||||
.map(spacing -> buildFormat(align, spacing))
|
.map(spacing -> buildFormat(align, spacing))
|
||||||
.map(format -> rows.stream()
|
.map(format -> rows.stream()
|
||||||
.map(row -> String.format(format, row.toArray()).substring(align == Align.RIGHT ? 2 : 0))
|
.map(
|
||||||
|
row -> String.format(format, row.toArray()).substring(align == Align.RIGHT ? 2 : 0))
|
||||||
.collect(toList()));
|
.collect(toList()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static String buildFormat(@NotNull final Align align, @NotNull final int[] spacing)
|
private static String buildFormat(@NotNull final Align align, @NotNull final int[] spacing) {
|
||||||
{
|
|
||||||
return stream(spacing)
|
return stream(spacing)
|
||||||
.mapToObj(space -> "%" + (align == Align.LEFT ? "-" : "") + (space + 2) + "s")
|
.mapToObj(space -> "%" + (align == Align.LEFT ? "-" : "") + (space + 2) + "s")
|
||||||
.collect(joining());
|
.collect(joining());
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static Optional<int[]> findSpacing(@NotNull final List<List<String>> rows)
|
private static Optional<int[]> findSpacing(@NotNull final List<List<String>> rows) {
|
||||||
{
|
|
||||||
return rows.stream()
|
return rows.stream()
|
||||||
.map(row -> row.stream().mapToInt(String::length).toArray())
|
.map(row -> row.stream().mapToInt(String::length).toArray())
|
||||||
.reduce((l, r) -> range(0, min(l.length, r.length)).map(i -> max(l[i], r[i])).toArray());
|
.reduce((l, r) -> range(0, min(l.length, r.length)).map(i -> max(l[i], r[i])).toArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public enum Align {
|
||||||
|
LEFT, RIGHT
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -20,10 +20,6 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.util;
|
package me.clip.placeholderapi.util;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.plugin.Plugin;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.concurrent.CompletableFuture;
|
import java.util.concurrent.CompletableFuture;
|
||||||
@ -31,23 +27,22 @@ import java.util.function.BiConsumer;
|
|||||||
import java.util.stream.Collector;
|
import java.util.stream.Collector;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.plugin.Plugin;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public final class Futures
|
public final class Futures {
|
||||||
{
|
|
||||||
|
|
||||||
private Futures()
|
private Futures() {}
|
||||||
{}
|
|
||||||
|
|
||||||
|
|
||||||
public static <T> void onMainThread(@NotNull final Plugin plugin, @NotNull final CompletableFuture<T> future, @NotNull final BiConsumer<T, Throwable> consumer)
|
public static <T> void onMainThread(@NotNull final Plugin plugin,
|
||||||
{
|
@NotNull final CompletableFuture<T> future,
|
||||||
|
@NotNull final BiConsumer<T, Throwable> consumer) {
|
||||||
future.whenComplete((value, exception) -> {
|
future.whenComplete((value, exception) -> {
|
||||||
if (Bukkit.isPrimaryThread())
|
if (Bukkit.isPrimaryThread()) {
|
||||||
{
|
|
||||||
consumer.accept(value, exception);
|
consumer.accept(value, exception);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
Bukkit.getScheduler().runTask(plugin, () -> consumer.accept(value, exception));
|
Bukkit.getScheduler().runTask(plugin, () -> consumer.accept(value, exception));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -55,28 +50,27 @@ public final class Futures
|
|||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public static <T> Collector<CompletableFuture<T>, ?, CompletableFuture<List<T>>> collector()
|
public static <T> Collector<CompletableFuture<T>, ?, CompletableFuture<List<T>>> collector() {
|
||||||
{
|
|
||||||
return Collectors.collectingAndThen(Collectors.toList(), Futures::of);
|
return Collectors.collectingAndThen(Collectors.toList(), Futures::of);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public static <T> CompletableFuture<List<T>> of(@NotNull final Stream<CompletableFuture<T>> futures)
|
public static <T> CompletableFuture<List<T>> of(
|
||||||
{
|
@NotNull final Stream<CompletableFuture<T>> futures) {
|
||||||
return of(futures.collect(Collectors.toList()));
|
return of(futures.collect(Collectors.toList()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public static <T> CompletableFuture<List<T>> of(@NotNull final Collection<CompletableFuture<T>> futures)
|
public static <T> CompletableFuture<List<T>> of(
|
||||||
{
|
@NotNull final Collection<CompletableFuture<T>> futures) {
|
||||||
return CompletableFuture.allOf(futures.toArray(new CompletableFuture[0]))
|
return CompletableFuture.allOf(futures.toArray(new CompletableFuture[0]))
|
||||||
.thenApplyAsync($ -> awaitCompletion(futures));
|
.thenApplyAsync($ -> awaitCompletion(futures));
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private static <T> List<T> awaitCompletion(@NotNull final Collection<CompletableFuture<T>> futures)
|
private static <T> List<T> awaitCompletion(
|
||||||
{
|
@NotNull final Collection<CompletableFuture<T>> futures) {
|
||||||
return futures.stream().map(CompletableFuture::join).collect(Collectors.toList());
|
return futures.stream().map(CompletableFuture::join).collect(Collectors.toList());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,39 +20,33 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.util;
|
package me.clip.placeholderapi.util;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.Arrays;
|
public final class Msg {
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
public final class Msg
|
public static void msg(@NotNull final CommandSender sender, @NotNull final String... messages) {
|
||||||
{
|
if (messages.length == 0) {
|
||||||
|
|
||||||
public static void msg(@NotNull final CommandSender sender, @NotNull final String... messages)
|
|
||||||
{
|
|
||||||
if (messages.length == 0)
|
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
sender.sendMessage(Arrays.stream(messages).map(Msg::color).collect(Collectors.joining("\n")));
|
sender.sendMessage(Arrays.stream(messages).map(Msg::color).collect(Collectors.joining("\n")));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void broadcast(@NotNull final String... messages)
|
public static void broadcast(@NotNull final String... messages) {
|
||||||
{
|
if (messages.length == 0) {
|
||||||
if (messages.length == 0)
|
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Bukkit.broadcastMessage(Arrays.stream(messages).map(Msg::color).collect(Collectors.joining("\n")));
|
Bukkit.broadcastMessage(
|
||||||
|
Arrays.stream(messages).map(Msg::color).collect(Collectors.joining("\n")));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String color(@NotNull final String text)
|
public static String color(@NotNull final String text) {
|
||||||
{
|
|
||||||
return ChatColor.translateAlternateColorCodes('&', text);
|
return ChatColor.translateAlternateColorCodes('&', text);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -121,7 +121,8 @@ public class TimeUtil {
|
|||||||
/**
|
/**
|
||||||
* Format the given value with s, m, h and d (seconds, minutes, hours and days)
|
* Format the given value with s, m, h and d (seconds, minutes, hours and days)
|
||||||
*
|
*
|
||||||
* @param duration {@link Duration} (eg, Duration.of(20, {@link ChronoUnit#SECONDS}) for 20 seconds)
|
* @param duration {@link Duration} (eg, Duration.of(20, {@link ChronoUnit#SECONDS}) for 20
|
||||||
|
* seconds)
|
||||||
* @return formatted time
|
* @return formatted time
|
||||||
*/
|
*/
|
||||||
public static String getTime(final Duration duration) {
|
public static String getTime(final Duration duration) {
|
||||||
|
@ -29,8 +29,7 @@ import org.bukkit.OfflinePlayer;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
public interface Values
|
public interface Values {
|
||||||
{
|
|
||||||
|
|
||||||
String SMALL_TEXT = "My name is %player_name%";
|
String SMALL_TEXT = "My name is %player_name%";
|
||||||
String LARGE_TEXT = "My name is %player_name% and my location is (%player_x%, %player_y%, %player_z%), this placeholder is invalid %server_name%";
|
String LARGE_TEXT = "My name is %player_name% and my location is (%player_x%, %player_y%, %player_z%), this placeholder is invalid %server_name%";
|
||||||
@ -44,8 +43,7 @@ public interface Values
|
|||||||
Replacer REGEX_REPLACER = new RegexReplacer(Replacer.Closure.PERCENT);
|
Replacer REGEX_REPLACER = new RegexReplacer(Replacer.Closure.PERCENT);
|
||||||
|
|
||||||
|
|
||||||
final class MockPlayerPlaceholderExpansion extends PlaceholderExpansion
|
final class MockPlayerPlaceholderExpansion extends PlaceholderExpansion {
|
||||||
{
|
|
||||||
|
|
||||||
public static final String PLAYER_X = "10";
|
public static final String PLAYER_X = "10";
|
||||||
public static final String PLAYER_Y = "20";
|
public static final String PLAYER_Y = "20";
|
||||||
@ -55,36 +53,30 @@ public interface Values
|
|||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Override
|
@Override
|
||||||
public String getIdentifier()
|
public String getIdentifier() {
|
||||||
{
|
|
||||||
return "player";
|
return "player";
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Override
|
@Override
|
||||||
public String getAuthor()
|
public String getAuthor() {
|
||||||
{
|
|
||||||
return "Sxtanna";
|
return "Sxtanna";
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Override
|
@Override
|
||||||
public String getVersion()
|
public String getVersion() {
|
||||||
{
|
|
||||||
return "1.0";
|
return "1.0";
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String onRequest(@Nullable final OfflinePlayer player, @NotNull final String params)
|
public String onRequest(@Nullable final OfflinePlayer player, @NotNull final String params) {
|
||||||
{
|
|
||||||
final String[] parts = params.split("_");
|
final String[] parts = params.split("_");
|
||||||
if (parts.length == 0)
|
if (parts.length == 0) {
|
||||||
{
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (parts[0])
|
switch (parts[0]) {
|
||||||
{
|
|
||||||
case "name":
|
case "name":
|
||||||
return PLAYER_NAME;
|
return PLAYER_NAME;
|
||||||
case "x":
|
case "x":
|
||||||
|
@ -23,30 +23,25 @@ package me.clip.placeholderapi.replacer;
|
|||||||
import me.clip.placeholderapi.Values;
|
import me.clip.placeholderapi.Values;
|
||||||
import org.openjdk.jmh.annotations.Benchmark;
|
import org.openjdk.jmh.annotations.Benchmark;
|
||||||
|
|
||||||
public class ReplacerBenchmarks
|
public class ReplacerBenchmarks {
|
||||||
{
|
|
||||||
|
|
||||||
@Benchmark
|
@Benchmark
|
||||||
public void measureCharsReplacerSmallText()
|
public void measureCharsReplacerSmallText() {
|
||||||
{
|
|
||||||
Values.CHARS_REPLACER.apply(Values.SMALL_TEXT, null, Values.PLACEHOLDERS::get);
|
Values.CHARS_REPLACER.apply(Values.SMALL_TEXT, null, Values.PLACEHOLDERS::get);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Benchmark
|
@Benchmark
|
||||||
public void measureRegexReplacerSmallText()
|
public void measureRegexReplacerSmallText() {
|
||||||
{
|
|
||||||
Values.REGEX_REPLACER.apply(Values.SMALL_TEXT, null, Values.PLACEHOLDERS::get);
|
Values.REGEX_REPLACER.apply(Values.SMALL_TEXT, null, Values.PLACEHOLDERS::get);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Benchmark
|
@Benchmark
|
||||||
public void measureCharsReplacerLargeText()
|
public void measureCharsReplacerLargeText() {
|
||||||
{
|
|
||||||
Values.CHARS_REPLACER.apply(Values.LARGE_TEXT, null, Values.PLACEHOLDERS::get);
|
Values.CHARS_REPLACER.apply(Values.LARGE_TEXT, null, Values.PLACEHOLDERS::get);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Benchmark
|
@Benchmark
|
||||||
public void measureRegexReplacerLargeText()
|
public void measureRegexReplacerLargeText() {
|
||||||
{
|
|
||||||
Values.REGEX_REPLACER.apply(Values.LARGE_TEXT, null, Values.PLACEHOLDERS::get);
|
Values.REGEX_REPLACER.apply(Values.LARGE_TEXT, null, Values.PLACEHOLDERS::get);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,47 +20,51 @@
|
|||||||
|
|
||||||
package me.clip.placeholderapi.replacer;
|
package me.clip.placeholderapi.replacer;
|
||||||
|
|
||||||
import me.clip.placeholderapi.Values;
|
|
||||||
import org.junit.jupiter.api.Test;
|
|
||||||
|
|
||||||
import static me.clip.placeholderapi.Values.MockPlayerPlaceholderExpansion.PLAYER_NAME;
|
import static me.clip.placeholderapi.Values.MockPlayerPlaceholderExpansion.PLAYER_NAME;
|
||||||
import static me.clip.placeholderapi.Values.MockPlayerPlaceholderExpansion.PLAYER_X;
|
import static me.clip.placeholderapi.Values.MockPlayerPlaceholderExpansion.PLAYER_X;
|
||||||
import static me.clip.placeholderapi.Values.MockPlayerPlaceholderExpansion.PLAYER_Y;
|
import static me.clip.placeholderapi.Values.MockPlayerPlaceholderExpansion.PLAYER_Y;
|
||||||
import static me.clip.placeholderapi.Values.MockPlayerPlaceholderExpansion.PLAYER_Z;
|
import static me.clip.placeholderapi.Values.MockPlayerPlaceholderExpansion.PLAYER_Z;
|
||||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
|
||||||
public final class ReplacerUnitTester
|
import me.clip.placeholderapi.Values;
|
||||||
{
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
public final class ReplacerUnitTester {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testCharsReplacerProducesExpectedSingleValue()
|
void testCharsReplacerProducesExpectedSingleValue() {
|
||||||
{
|
assertEquals(PLAYER_NAME,
|
||||||
assertEquals(PLAYER_NAME, Values.CHARS_REPLACER.apply("%player_name%", null, Values.PLACEHOLDERS::get));
|
Values.CHARS_REPLACER.apply("%player_name%", null, Values.PLACEHOLDERS::get));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testRegexReplacerProducesExpectedSingleValue()
|
void testRegexReplacerProducesExpectedSingleValue() {
|
||||||
{
|
assertEquals(PLAYER_NAME,
|
||||||
assertEquals(PLAYER_NAME, Values.REGEX_REPLACER.apply("%player_name%", null, Values.PLACEHOLDERS::get));
|
Values.REGEX_REPLACER.apply("%player_name%", null, Values.PLACEHOLDERS::get));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testCharsReplacerProducesExpectedSentence()
|
void testCharsReplacerProducesExpectedSentence() {
|
||||||
{
|
assertEquals(String.format(
|
||||||
assertEquals(String.format("My name is %s and my location is (%s, %s, %s), this placeholder is invalid %%server_name%%", PLAYER_NAME, PLAYER_X, PLAYER_Y, PLAYER_Z), Values.CHARS_REPLACER.apply(Values.LARGE_TEXT, null, Values.PLACEHOLDERS::get));
|
"My name is %s and my location is (%s, %s, %s), this placeholder is invalid %%server_name%%",
|
||||||
|
PLAYER_NAME, PLAYER_X, PLAYER_Y, PLAYER_Z),
|
||||||
|
Values.CHARS_REPLACER.apply(Values.LARGE_TEXT, null, Values.PLACEHOLDERS::get));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testRegexReplacerProducesExpectedSentence()
|
void testRegexReplacerProducesExpectedSentence() {
|
||||||
{
|
assertEquals(String.format(
|
||||||
assertEquals(String.format("My name is %s and my location is (%s, %s, %s), this placeholder is invalid %%server_name%%", PLAYER_NAME, PLAYER_X, PLAYER_Y, PLAYER_Z), Values.REGEX_REPLACER.apply(Values.LARGE_TEXT, null, Values.PLACEHOLDERS::get));
|
"My name is %s and my location is (%s, %s, %s), this placeholder is invalid %%server_name%%",
|
||||||
|
PLAYER_NAME, PLAYER_X, PLAYER_Y, PLAYER_Z),
|
||||||
|
Values.REGEX_REPLACER.apply(Values.LARGE_TEXT, null, Values.PLACEHOLDERS::get));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testResultsAreTheSameAsReplacement()
|
void testResultsAreTheSameAsReplacement() {
|
||||||
{
|
final String resultChars = Values.CHARS_REPLACER
|
||||||
final String resultChars = Values.CHARS_REPLACER.apply("%player_name%", null, Values.PLACEHOLDERS::get);
|
.apply("%player_name%", null, Values.PLACEHOLDERS::get);
|
||||||
final String resultRegex = Values.REGEX_REPLACER.apply("%player_name%", null, Values.PLACEHOLDERS::get);
|
final String resultRegex = Values.REGEX_REPLACER
|
||||||
|
.apply("%player_name%", null, Values.PLACEHOLDERS::get);
|
||||||
|
|
||||||
assertEquals(resultChars, resultRegex);
|
assertEquals(resultChars, resultRegex);
|
||||||
|
|
||||||
@ -68,28 +72,28 @@ public final class ReplacerUnitTester
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testResultsAreTheSameNoReplacement()
|
void testResultsAreTheSameNoReplacement() {
|
||||||
{
|
final String resultChars = Values.CHARS_REPLACER
|
||||||
final String resultChars = Values.CHARS_REPLACER.apply("%player_location%", null, Values.PLACEHOLDERS::get);
|
.apply("%player_location%", null, Values.PLACEHOLDERS::get);
|
||||||
final String resultRegex = Values.REGEX_REPLACER.apply("%player_location%", null, Values.PLACEHOLDERS::get);
|
final String resultRegex = Values.REGEX_REPLACER
|
||||||
|
.apply("%player_location%", null, Values.PLACEHOLDERS::get);
|
||||||
|
|
||||||
assertEquals(resultChars, resultRegex);
|
assertEquals(resultChars, resultRegex);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testCharsReplacerIgnoresMalformed()
|
void testCharsReplacerIgnoresMalformed() {
|
||||||
{
|
|
||||||
final String text = "10% and %hello world 15%";
|
final String text = "10% and %hello world 15%";
|
||||||
|
|
||||||
assertEquals(text, Values.CHARS_REPLACER.apply(text, null, Values.PLACEHOLDERS::get));
|
assertEquals(text, Values.CHARS_REPLACER.apply(text, null, Values.PLACEHOLDERS::get));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testCharsReplacerHandlesEscapedHex()
|
void testCharsReplacerHandlesEscapedHex() {
|
||||||
{
|
|
||||||
final String text = "\\&xffffffThis should not change.";
|
final String text = "\\&xffffffThis should not change.";
|
||||||
|
|
||||||
assertEquals(text.substring(1), Values.CHARS_REPLACER.apply(text, null, Values.PLACEHOLDERS::get));
|
assertEquals(text.substring(1),
|
||||||
|
Values.CHARS_REPLACER.apply(text, null, Values.PLACEHOLDERS::get));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user