版本更新至:4.04
调整:命令帮助的格式现在可以在语言文件中更改了。 调整:@CommandRegister 现在可以直接标注在 BaseSubCommand 成员变量上进行注册了(详见 TabooLibPluginMainCommand 写法)。 调整:TagAPI,TagManager 作废,但部分方法仍可使用。 新增:BaseSubCommand 类新增 getPermission 方法用于判断子命令权限 新增:TagDataHandler 类用于代替 TagManager 类 新增:TagPacket 类用于代替 TagAPI 类 修复:前后缀以及昵称的各种不兼容问题 修复:ItemUtils 工具载入物品时因 material 值不存在而导致的报错 删除:me.skymc.taboolib.team.TagUtils 类永久删除
This commit is contained in:
parent
ffa2d616c4
commit
0acf324b15
@ -1,113 +1,61 @@
|
|||||||
package com.ilummc.tlib.inject;
|
package com.ilummc.tlib.inject;
|
||||||
|
|
||||||
|
import com.google.common.collect.Lists;
|
||||||
import com.google.common.io.Files;
|
import com.google.common.io.Files;
|
||||||
import com.google.gson.Gson;
|
import com.google.gson.Gson;
|
||||||
import com.google.gson.GsonBuilder;
|
import com.google.gson.GsonBuilder;
|
||||||
import com.ilummc.tlib.annotations.TConfig;
|
import com.google.gson.annotations.SerializedName;
|
||||||
import com.ilummc.tlib.resources.TLocale;
|
import com.ilummc.tlib.TLib;
|
||||||
import me.skymc.taboolib.fileutils.ConfigUtils;
|
import com.ilummc.tlib.annotations.Config;
|
||||||
|
import com.ilummc.tlib.bean.Property;
|
||||||
import org.apache.commons.lang3.Validate;
|
import org.apache.commons.lang3.Validate;
|
||||||
import org.bukkit.configuration.file.YamlConfiguration;
|
import org.bukkit.configuration.serialization.ConfigurationSerializable;
|
||||||
|
import org.bukkit.configuration.serialization.ConfigurationSerialization;
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
import org.yaml.snakeyaml.DumperOptions;
|
import org.yaml.snakeyaml.DumperOptions;
|
||||||
|
import org.yaml.snakeyaml.Yaml;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.lang.reflect.Array;
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
import java.util.HashMap;
|
import java.util.*;
|
||||||
import java.util.Map;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
public class TConfigInjector {
|
public class TConfigInjector {
|
||||||
|
|
||||||
public static void fixUnicode(YamlConfiguration configuration) {
|
|
||||||
try {
|
|
||||||
Field field = YamlConfiguration.class.getDeclaredField("yamlOptions");
|
|
||||||
field.setAccessible(true);
|
|
||||||
field.set(configuration, NoUnicodeDumperOption.INSTANCE);
|
|
||||||
} catch (NoSuchFieldException | IllegalAccessException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final class NoUnicodeDumperOption extends DumperOptions {
|
|
||||||
|
|
||||||
private static final NoUnicodeDumperOption INSTANCE = new NoUnicodeDumperOption();
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setAllowUnicode(boolean allowUnicode) {
|
|
||||||
super.setAllowUnicode(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isAllowUnicode() {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setLineBreak(LineBreak lineBreak) {
|
|
||||||
super.setLineBreak(LineBreak.getPlatformLineBreak());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Object loadConfig(Plugin plugin, Class<?> clazz) {
|
public static Object loadConfig(Plugin plugin, Class<?> clazz) {
|
||||||
try {
|
try {
|
||||||
TConfig config = clazz.getAnnotation(TConfig.class);
|
Config config = clazz.getAnnotation(Config.class);
|
||||||
Validate.notNull(config);
|
Validate.notNull(config);
|
||||||
File file = new File(plugin.getDataFolder(), config.name());
|
File file = new File(plugin.getDataFolder(), config.name());
|
||||||
if (!file.exists()) {
|
if (!file.exists()) if (config.fromJar()) plugin.saveResource(config.name(), true);
|
||||||
if (config.fromJar()) {
|
else saveConfig(plugin, clazz.newInstance());
|
||||||
plugin.saveResource(config.name(), true);
|
return unserialize(plugin, clazz);
|
||||||
} else {
|
|
||||||
saveConfig(plugin, clazz.newInstance());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Object obj = unserialize(plugin, clazz);
|
|
||||||
if (config.readOnly()) {
|
|
||||||
saveConfig(plugin, obj);
|
|
||||||
}
|
|
||||||
return obj;
|
|
||||||
} catch (NullPointerException e) {
|
} catch (NullPointerException e) {
|
||||||
TLocale.Logger.warn("CONFIG.LOAD-FAIL-NO-ANNOTATION", plugin.toString(), clazz.getSimpleName());
|
TLib.getTLib().getLogger().warn("插件 " + plugin + " 的配置类 " + clazz.getSimpleName() + " 加载失败:没有 @Config 注解");
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
TLocale.Logger.warn("CONFIG.LOAD-FAIL", plugin.toString(), clazz.getSimpleName());
|
TLib.getTLib().getLogger().warn("插件 " + plugin + " 的配置类 " + clazz.getSimpleName() + " 加载失败");
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void reloadConfig(Plugin plugin, Object object) {
|
|
||||||
try {
|
|
||||||
TConfig config = object.getClass().getAnnotation(TConfig.class);
|
|
||||||
Validate.notNull(config);
|
|
||||||
File file = new File(plugin.getDataFolder(), config.name());
|
|
||||||
Map<String, Object> map = ConfigUtils.confToMap(ConfigUtils.loadYaml(plugin, file));
|
|
||||||
Object obj = ConfigUtils.mapToObj(map, object);
|
|
||||||
if (config.readOnly()) {
|
|
||||||
saveConfig(plugin, obj);
|
|
||||||
}
|
|
||||||
} catch (NullPointerException e) {
|
|
||||||
TLocale.Logger.warn("CONFIG.LOAD-FAIL-NO-ANNOTATION", plugin.toString(), object.getClass().getSimpleName());
|
|
||||||
} catch (Exception e) {
|
|
||||||
TLocale.Logger.warn("CONFIG.LOAD-FAIL", plugin.toString(), object.getClass().getSimpleName());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Object unserialize(Plugin plugin, Class<?> clazz) {
|
public static Object unserialize(Plugin plugin, Class<?> clazz) {
|
||||||
try {
|
try {
|
||||||
TConfig config = clazz.getAnnotation(TConfig.class);
|
Config config = clazz.getAnnotation(Config.class);
|
||||||
Validate.notNull(config);
|
Validate.notNull(config);
|
||||||
return ConfigUtils.confToObj(
|
return new GsonBuilder().disableHtmlEscaping().excludeFieldsWithModifiers(config.excludeModifiers())
|
||||||
ConfigUtils.mapToConf(
|
.create().fromJson(new Gson().toJson(new Yaml()
|
||||||
ConfigUtils.yamlToMap(
|
.dump(Files.toString(new File(plugin.getDataFolder(), config.name()), Charset.forName(config.charset())))), clazz);
|
||||||
Files.toString(new File(plugin.getDataFolder(), config.name()), Charset.forName(config.charset())))), clazz);
|
|
||||||
} catch (NullPointerException e) {
|
} catch (NullPointerException e) {
|
||||||
TLocale.Logger.warn("CONFIG.LOAD-FAIL-NO-FILE", plugin.toString(), clazz.getSimpleName());
|
TLib.getTLib().getLogger().warn("插件 " + plugin + " 的配置类 " + clazz.getSimpleName() + " 加载失败:没有 @Config 注解或文件不存在");
|
||||||
return null;
|
return null;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
try {
|
try {
|
||||||
return clazz.newInstance();
|
return clazz.newInstance();
|
||||||
} catch (InstantiationException | IllegalAccessException e1) {
|
} catch (InstantiationException | IllegalAccessException e1) {
|
||||||
TLocale.Logger.warn("CONFIG.LOAD-FAIL", plugin.toString(), clazz.getSimpleName());
|
TLib.getTLib().getLogger().warn("插件 " + plugin + " 的配置类 " + clazz.getSimpleName() + " 加载失败");
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -115,29 +63,95 @@ public class TConfigInjector {
|
|||||||
|
|
||||||
public static Map<String, Object> serialize(Plugin plugin, Object object) {
|
public static Map<String, Object> serialize(Plugin plugin, Object object) {
|
||||||
try {
|
try {
|
||||||
TConfig config = object.getClass().getAnnotation(TConfig.class);
|
Config config = object.getClass().getAnnotation(Config.class);
|
||||||
Validate.notNull(config);
|
Validate.notNull(config);
|
||||||
return ConfigUtils.objToMap(ConfigUtils.objToConf(object).getValues(false), config.excludeModifiers());
|
return new Serializer(new LinkedHashMap<>(), object, config.excludeModifiers()).get();
|
||||||
} catch (NullPointerException e) {
|
} catch (NullPointerException e) {
|
||||||
TLocale.Logger.warn("CONFIG.SAVE-FAIL-NO-ANNOTATION", plugin.toString(), object.getClass().getSimpleName());
|
TLib.getTLib().getLogger().warn("插件 " + plugin + " 的配置类 " + object.getClass().getSimpleName() + " 序列化失败:没有 @Config 注解");
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
TLocale.Logger.warn("CONFIG.SAVE-FAIL", plugin.toString(), object.getClass().getSimpleName());
|
TLib.getTLib().getLogger().warn("插件 " + plugin + " 的配置类 " + object.getClass().getSimpleName() + " 序列化失败");
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void saveConfig(Plugin plugin, Object object) throws IOException, NullPointerException {
|
public static void saveConfig(Plugin plugin, Object object) throws IOException, NullPointerException {
|
||||||
TConfig config = object.getClass().getAnnotation(TConfig.class);
|
Config config = object.getClass().getAnnotation(Config.class);
|
||||||
Validate.notNull(config);
|
Validate.notNull(config);
|
||||||
Gson gson = new GsonBuilder().disableHtmlEscaping().create();
|
Object obj = serialize(plugin, object);
|
||||||
Map map = gson.fromJson(gson.toJson(object), HashMap.class);
|
Validate.notNull(obj);
|
||||||
YamlConfiguration configuration = (YamlConfiguration) ConfigUtils.mapToConf(map);
|
|
||||||
File target = new File(plugin.getDataFolder(), config.name());
|
File target = new File(plugin.getDataFolder(), config.name());
|
||||||
if (!target.exists()) {
|
if (!target.exists()) target.createNewFile();
|
||||||
target.createNewFile();
|
DumperOptions options = new DumperOptions();
|
||||||
}
|
options.setDefaultFlowStyle(DumperOptions.FlowStyle.BLOCK);
|
||||||
byte[] arr = configuration.saveToString().getBytes(config.charset());
|
Yaml yaml = new Yaml(options);
|
||||||
|
String str = yaml.dump(obj);
|
||||||
|
byte[] arr = str.getBytes(config.charset());
|
||||||
Files.write(arr, target);
|
Files.write(arr, target);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static final List<Class<?>> primitiveType = Lists.newArrayList(Integer.class,
|
||||||
|
Double.class, Float.class, Boolean.class, Short.class, Byte.class, Character.class, Long.class, String.class);
|
||||||
|
|
||||||
|
private static class Serializer {
|
||||||
|
|
||||||
|
private HashMap<String, Object> map;
|
||||||
|
private Object o;
|
||||||
|
private int modifiers;
|
||||||
|
|
||||||
|
private Serializer(HashMap<String, Object> map, Object o, int modifiers) {
|
||||||
|
this.map = map;
|
||||||
|
this.o = o;
|
||||||
|
this.modifiers = modifiers;
|
||||||
|
}
|
||||||
|
|
||||||
|
private HashMap<String, Object> get() {
|
||||||
|
for (Field field : o.getClass().getDeclaredFields()) {
|
||||||
|
if ((field.getModifiers() & modifiers) == 0 && !field.isSynthetic())
|
||||||
|
try {
|
||||||
|
SerializedName node = field.getAnnotation(SerializedName.class);
|
||||||
|
if (!field.isAccessible()) field.setAccessible(true);
|
||||||
|
Object obj = field.get(o);
|
||||||
|
map.put(node == null ? field.getName() : node.value(), serialize(obj));
|
||||||
|
} catch (Exception ignored) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings({"unchecked", "rawtypes"})
|
||||||
|
private Object serialize(Object o) {
|
||||||
|
try {
|
||||||
|
if (o.getClass().isPrimitive() || primitiveType.contains(o.getClass())) {
|
||||||
|
return o;
|
||||||
|
} else if (o.getClass().isArray()) {
|
||||||
|
List list = new ArrayList<>();
|
||||||
|
int len = (int) o.getClass().getField("length").get(o);
|
||||||
|
for (int i = 0; i < len; i++) {
|
||||||
|
list.add(serialize(Array.get(o, i)));
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
} else if (o instanceof Collection) {
|
||||||
|
return ((Collection) o).stream().map(this::serialize).collect(Collectors.toList());
|
||||||
|
} else if (o instanceof Map) {
|
||||||
|
Map map = new LinkedHashMap<>();
|
||||||
|
((Map) o).forEach((o1, o2) -> map.put((String) o1, serialize(o2)));
|
||||||
|
return map;
|
||||||
|
} else if (o instanceof ConfigurationSerializable) {
|
||||||
|
Map map = new LinkedHashMap<>();
|
||||||
|
map.put(ConfigurationSerialization.SERIALIZED_TYPE_KEY,
|
||||||
|
ConfigurationSerialization.getAlias((Class<? extends ConfigurationSerializable>) o.getClass()));
|
||||||
|
map.putAll(((ConfigurationSerializable) o).serialize());
|
||||||
|
return map;
|
||||||
|
} else if (o instanceof Property) {
|
||||||
|
return serialize(((Property) o).get());
|
||||||
|
} else {
|
||||||
|
return new Serializer(new HashMap<>(), o, modifiers).get();
|
||||||
|
}
|
||||||
|
} catch (Exception ignored) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -8,6 +8,7 @@ import me.skymc.taboolib.anvil.AnvilContainerAPI;
|
|||||||
import me.skymc.taboolib.bstats.Metrics;
|
import me.skymc.taboolib.bstats.Metrics;
|
||||||
import me.skymc.taboolib.commands.TabooLibMainCommand;
|
import me.skymc.taboolib.commands.TabooLibMainCommand;
|
||||||
import me.skymc.taboolib.commands.internal.BaseMainCommand;
|
import me.skymc.taboolib.commands.internal.BaseMainCommand;
|
||||||
|
import me.skymc.taboolib.commands.internal.TBaseCommand;
|
||||||
import me.skymc.taboolib.commands.language.Language2Command;
|
import me.skymc.taboolib.commands.language.Language2Command;
|
||||||
import me.skymc.taboolib.commands.locale.TabooLibLocaleCommand;
|
import me.skymc.taboolib.commands.locale.TabooLibLocaleCommand;
|
||||||
import me.skymc.taboolib.commands.plugin.TabooLibPluginMainCommand;
|
import me.skymc.taboolib.commands.plugin.TabooLibPluginMainCommand;
|
||||||
@ -21,6 +22,7 @@ import me.skymc.taboolib.fileutils.ConfigUtils;
|
|||||||
import me.skymc.taboolib.fileutils.FileUtils;
|
import me.skymc.taboolib.fileutils.FileUtils;
|
||||||
import me.skymc.taboolib.inventory.ItemUtils;
|
import me.skymc.taboolib.inventory.ItemUtils;
|
||||||
import me.skymc.taboolib.inventory.speciaitem.SpecialItem;
|
import me.skymc.taboolib.inventory.speciaitem.SpecialItem;
|
||||||
|
import me.skymc.taboolib.itagapi.TagDataHandler;
|
||||||
import me.skymc.taboolib.javashell.JavaShell;
|
import me.skymc.taboolib.javashell.JavaShell;
|
||||||
import me.skymc.taboolib.listener.*;
|
import me.skymc.taboolib.listener.*;
|
||||||
import me.skymc.taboolib.message.ChatCatcher;
|
import me.skymc.taboolib.message.ChatCatcher;
|
||||||
@ -28,7 +30,6 @@ import me.skymc.taboolib.mysql.hikari.HikariHandler;
|
|||||||
import me.skymc.taboolib.mysql.protect.MySQLConnection;
|
import me.skymc.taboolib.mysql.protect.MySQLConnection;
|
||||||
import me.skymc.taboolib.nms.item.DabItemUtils;
|
import me.skymc.taboolib.nms.item.DabItemUtils;
|
||||||
import me.skymc.taboolib.other.NumberUtils;
|
import me.skymc.taboolib.other.NumberUtils;
|
||||||
import me.skymc.taboolib.packet.PacketUtils;
|
|
||||||
import me.skymc.taboolib.permission.PermissionUtils;
|
import me.skymc.taboolib.permission.PermissionUtils;
|
||||||
import me.skymc.taboolib.playerdata.DataUtils;
|
import me.skymc.taboolib.playerdata.DataUtils;
|
||||||
import me.skymc.taboolib.sign.SignUtils;
|
import me.skymc.taboolib.sign.SignUtils;
|
||||||
@ -36,8 +37,6 @@ import me.skymc.taboolib.skript.SkriptHandler;
|
|||||||
import me.skymc.taboolib.string.StringUtils;
|
import me.skymc.taboolib.string.StringUtils;
|
||||||
import me.skymc.taboolib.string.language2.Language2;
|
import me.skymc.taboolib.string.language2.Language2;
|
||||||
import me.skymc.taboolib.support.SupportPlaceholder;
|
import me.skymc.taboolib.support.SupportPlaceholder;
|
||||||
import me.skymc.taboolib.team.TagAPI;
|
|
||||||
import me.skymc.taboolib.team.TagUtils;
|
|
||||||
import me.skymc.taboolib.timecycle.TimeCycleManager;
|
import me.skymc.taboolib.timecycle.TimeCycleManager;
|
||||||
import me.skymc.taboolib.update.UpdateTask;
|
import me.skymc.taboolib.update.UpdateTask;
|
||||||
import me.skymc.tlm.TLM;
|
import me.skymc.tlm.TLM;
|
||||||
@ -150,6 +149,8 @@ public class Main extends JavaPlugin implements Listener {
|
|||||||
JavaShell.javaShellSetup();
|
JavaShell.javaShellSetup();
|
||||||
// 注册脚本
|
// 注册脚本
|
||||||
SkriptHandler.getInst();
|
SkriptHandler.getInst();
|
||||||
|
// 注册头衔
|
||||||
|
TagDataHandler.init(this);
|
||||||
// 载入语言文件
|
// 载入语言文件
|
||||||
exampleLanguage2 = new Language2("Language2", this);
|
exampleLanguage2 = new Language2("Language2", this);
|
||||||
|
|
||||||
@ -180,10 +181,6 @@ public class Main extends JavaPlugin implements Listener {
|
|||||||
if (Bukkit.getPluginManager().getPlugin("PlaceholderAPI") != null) {
|
if (Bukkit.getPluginManager().getPlugin("PlaceholderAPI") != null) {
|
||||||
new SupportPlaceholder(getInst(), "taboolib").hook();
|
new SupportPlaceholder(getInst(), "taboolib").hook();
|
||||||
}
|
}
|
||||||
// 载入 ProtocolLib 扩展
|
|
||||||
if (PacketUtils.isProtocolLibEnabled()) {
|
|
||||||
TagAPI.inst();
|
|
||||||
}
|
|
||||||
// 载入 SpecialItem 接口
|
// 载入 SpecialItem 接口
|
||||||
SpecialItem.getInst().loadItems();
|
SpecialItem.getInst().loadItems();
|
||||||
// 载入 TLM 接口
|
// 载入 TLM 接口
|
||||||
@ -244,9 +241,6 @@ public class Main extends JavaPlugin implements Listener {
|
|||||||
// 提示信息
|
// 提示信息
|
||||||
TLocale.Logger.error("NOTIFY.SUCCESS-DISABLE");
|
TLocale.Logger.error("NOTIFY.SUCCESS-DISABLE");
|
||||||
|
|
||||||
// 清理头衔
|
|
||||||
TagUtils.delete();
|
|
||||||
|
|
||||||
// 结束连接
|
// 结束连接
|
||||||
if (connection != null && connection.isConnection()) {
|
if (connection != null && connection.isConnection()) {
|
||||||
connection.closeConnection();
|
connection.closeConnection();
|
||||||
@ -332,8 +326,8 @@ public class Main extends JavaPlugin implements Listener {
|
|||||||
getCommand("language2").setExecutor(new Language2Command());
|
getCommand("language2").setExecutor(new Language2Command());
|
||||||
getCommand("taboolibrarymodule").setExecutor(new TLMCommands());
|
getCommand("taboolibrarymodule").setExecutor(new TLMCommands());
|
||||||
getCommand("tabooliblocale").setExecutor(new TabooLibLocaleCommand());
|
getCommand("tabooliblocale").setExecutor(new TabooLibLocaleCommand());
|
||||||
BaseMainCommand.createCommandExecutor("taboolib", new TabooLibMainCommand());
|
TBaseCommand.registerCommand("taboolib", new TabooLibMainCommand());
|
||||||
BaseMainCommand.createCommandExecutor("taboolibplugin", new TabooLibPluginMainCommand());
|
TBaseCommand.registerCommand("taboolibplugin", new TabooLibPluginMainCommand());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void registerListener() {
|
private void registerListener() {
|
||||||
|
@ -224,7 +224,7 @@ public class Metrics {
|
|||||||
playerAmount = Bukkit.getOnlinePlayers().size();
|
playerAmount = Bukkit.getOnlinePlayers().size();
|
||||||
}
|
}
|
||||||
int onlineMode = Bukkit.getOnlineMode() ? 1 : 0;
|
int onlineMode = Bukkit.getOnlineMode() ? 1 : 0;
|
||||||
String bukkitVersion = org.bukkit.Bukkit.getVersion();
|
String bukkitVersion = Bukkit.getVersion();
|
||||||
bukkitVersion = bukkitVersion.substring(bukkitVersion.indexOf("MC: ") + 4, bukkitVersion.length() - 1);
|
bukkitVersion = bukkitVersion.substring(bukkitVersion.indexOf("MC: ") + 4, bukkitVersion.length() - 1);
|
||||||
|
|
||||||
// OS/Java specific data
|
// OS/Java specific data
|
||||||
|
@ -22,8 +22,7 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@CommandRegister(priority = 1)
|
@CommandRegister(priority = 1)
|
||||||
void save() {
|
BaseSubCommand save = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -49,12 +48,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 2)
|
@CommandRegister(priority = 2)
|
||||||
void item() {
|
BaseSubCommand item = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -84,12 +81,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 3)
|
@CommandRegister(priority = 3)
|
||||||
void itemInfo() {
|
BaseSubCommand itemInfo = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -110,12 +105,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
new InfoCommand(sender, args);
|
new InfoCommand(sender, args);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 3.1)
|
@CommandRegister(priority = 3.1)
|
||||||
void infoList() {
|
BaseSubCommand infoList = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -141,12 +134,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 4)
|
@CommandRegister(priority = 4)
|
||||||
void itemReload() {
|
BaseSubCommand itemReload = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -169,17 +160,13 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
ItemUtils.reloadItemName();
|
ItemUtils.reloadItemName();
|
||||||
TLocale.sendTo(sender, "COMMANDS.TABOOLIB.ITEMRELOAD.SUCCESS-RELOAD");
|
TLocale.sendTo(sender, "COMMANDS.TABOOLIB.ITEMRELOAD.SUCCESS-RELOAD");
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 5)
|
@CommandRegister(priority = 5)
|
||||||
void emptyLine1() {
|
BaseSubCommand emptyLine1 = null;
|
||||||
registerSubCommand(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 6)
|
@CommandRegister(priority = 6)
|
||||||
void attributes() {
|
BaseSubCommand attributes = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -200,12 +187,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
new AttributesCommand(sender, args);
|
new AttributesCommand(sender, args);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 7)
|
@CommandRegister(priority = 7)
|
||||||
void enchants() {
|
BaseSubCommand enchants = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -226,12 +211,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
new EnchantCommand(sender, args);
|
new EnchantCommand(sender, args);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 8)
|
@CommandRegister(priority = 8)
|
||||||
void potions() {
|
BaseSubCommand potions = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -252,12 +235,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
new PotionCommand(sender, args);
|
new PotionCommand(sender, args);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 9)
|
@CommandRegister(priority = 9)
|
||||||
void flags() {
|
BaseSubCommand flags = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -278,12 +259,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
new FlagCommand(sender, args);
|
new FlagCommand(sender, args);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 10)
|
@CommandRegister(priority = 10)
|
||||||
void slots() {
|
BaseSubCommand slots = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -304,12 +283,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
new AttributesCommand(sender, args);
|
new AttributesCommand(sender, args);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 11)
|
@CommandRegister(priority = 11)
|
||||||
void sounds() {
|
BaseSubCommand sounds = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -335,17 +312,13 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 12)
|
@CommandRegister(priority = 12)
|
||||||
void emptyLine2() {
|
BaseSubCommand emptyLine2 = null;
|
||||||
registerSubCommand(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 13)
|
@CommandRegister(priority = 13)
|
||||||
void getVariable() {
|
BaseSubCommand getVariable = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -374,12 +347,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 13.1)
|
@CommandRegister(priority = 13.1)
|
||||||
void setVariable() {
|
BaseSubCommand setVariable = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -409,17 +380,13 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 13.2)
|
@CommandRegister(priority = 13.2)
|
||||||
void emptyLine3() {
|
BaseSubCommand getEmptyLine3 = null;
|
||||||
registerSubCommand(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 13.3)
|
@CommandRegister(priority = 13.3)
|
||||||
void cycleList() {
|
BaseSubCommand cycleList = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -440,12 +407,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
new CycleListCommand(sender, args);
|
new CycleListCommand(sender, args);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 14)
|
@CommandRegister(priority = 14)
|
||||||
void cycleInfo() {
|
BaseSubCommand cycleInfo = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -473,12 +438,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 15)
|
@CommandRegister(priority = 15)
|
||||||
void cycleReset() {
|
BaseSubCommand cycleReset = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -506,12 +469,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 16)
|
@CommandRegister(priority = 16)
|
||||||
void cycleUpdate() {
|
BaseSubCommand cycleUpdate = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -539,17 +500,13 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 17)
|
@CommandRegister(priority = 17)
|
||||||
void emptyLine4() {
|
BaseSubCommand getEmptyLine4 = null;
|
||||||
registerSubCommand(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 18)
|
@CommandRegister(priority = 18)
|
||||||
void shellLoad() {
|
BaseSubCommand shellLoad = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -577,12 +534,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 19)
|
@CommandRegister(priority = 19)
|
||||||
void shellUnload() {
|
BaseSubCommand shellUnload = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -610,17 +565,13 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 20)
|
@CommandRegister(priority = 20)
|
||||||
void emptyLine5() {
|
BaseSubCommand getEmptyLine5 = null;
|
||||||
registerSubCommand(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 20.5)
|
@CommandRegister(priority = 20.5)
|
||||||
void tagDisplay() {
|
BaseSubCommand tagDisplay = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -649,12 +600,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 21)
|
@CommandRegister(priority = 21)
|
||||||
void tagPrefix() {
|
BaseSubCommand tagPrefix = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -683,12 +632,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 22)
|
@CommandRegister(priority = 22)
|
||||||
void tagSuffix() {
|
BaseSubCommand tagSuffix = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -717,12 +664,10 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 23)
|
@CommandRegister(priority = 23)
|
||||||
void tagDelete() {
|
BaseSubCommand tagDelete = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -750,17 +695,13 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public boolean ignoredLabel() {
|
public boolean ignoredLabel() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 24)
|
@CommandRegister(priority = 24)
|
||||||
void emptyLine6() {
|
BaseSubCommand getEmptyLine6 = null;
|
||||||
registerSubCommand(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@CommandRegister(priority = 25)
|
@CommandRegister(priority = 25)
|
||||||
void importData() {
|
BaseSubCommand importData = new BaseSubCommand() {
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -781,6 +722,5 @@ public class TabooLibMainCommand extends BaseMainCommand {
|
|||||||
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public void onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
new ImportCommand(sender, args);
|
new ImportCommand(sender, args);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -2,10 +2,9 @@ package me.skymc.taboolib.commands.internal;
|
|||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
import com.ilummc.tlib.resources.TLocale;
|
import com.ilummc.tlib.resources.TLocale;
|
||||||
import com.ilummc.tlib.resources.TLocaleLoader;
|
|
||||||
import com.ilummc.tlib.util.Ref;
|
|
||||||
import me.skymc.taboolib.Main;
|
import me.skymc.taboolib.Main;
|
||||||
import me.skymc.taboolib.TabooLib;
|
import me.skymc.taboolib.TabooLib;
|
||||||
|
import me.skymc.taboolib.commands.internal.type.CommandField;
|
||||||
import me.skymc.taboolib.commands.internal.type.CommandRegister;
|
import me.skymc.taboolib.commands.internal.type.CommandRegister;
|
||||||
import me.skymc.taboolib.commands.internal.type.CommandType;
|
import me.skymc.taboolib.commands.internal.type.CommandType;
|
||||||
import me.skymc.taboolib.string.ArrayUtils;
|
import me.skymc.taboolib.string.ArrayUtils;
|
||||||
@ -47,6 +46,7 @@ public abstract class BaseMainCommand implements IMainCommand, CommandExecutor,
|
|||||||
|
|
||||||
public static void loadCommandRegister(BaseMainCommand baseMainCommand) {
|
public static void loadCommandRegister(BaseMainCommand baseMainCommand) {
|
||||||
List<Method> methods = new ArrayList<>();
|
List<Method> methods = new ArrayList<>();
|
||||||
|
List<CommandField> fields = new ArrayList<>();
|
||||||
baseMainCommand.getLinkClasses().forEach(clazz -> Arrays.stream(clazz.getDeclaredMethods()).filter(method -> method.getAnnotation(CommandRegister.class) != null).forEach(methods::add));
|
baseMainCommand.getLinkClasses().forEach(clazz -> Arrays.stream(clazz.getDeclaredMethods()).filter(method -> method.getAnnotation(CommandRegister.class) != null).forEach(methods::add));
|
||||||
if (methods.size() > 0) {
|
if (methods.size() > 0) {
|
||||||
methods.sort(Comparator.comparingDouble(a -> a.getAnnotation(CommandRegister.class).priority()));
|
methods.sort(Comparator.comparingDouble(a -> a.getAnnotation(CommandRegister.class).priority()));
|
||||||
@ -58,8 +58,19 @@ public abstract class BaseMainCommand implements IMainCommand, CommandExecutor,
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
if (methods.size() > 0) {
|
baseMainCommand.getLinkClasses().forEach(clazz -> Arrays.stream(clazz.getDeclaredFields()).filter(field -> field.getAnnotation(CommandRegister.class) != null && field.getType().equals(BaseSubCommand.class)).forEach(field -> fields.add(new CommandField(field, clazz))));
|
||||||
TLocale.Logger.info("COMMANDS.INTERNAL.COMMAND-REGISTER", baseMainCommand.getRegisterCommand().getPlugin().getName(), baseMainCommand.getRegisterCommand().getName(), String.valueOf(methods.size()));
|
if (fields.size() > 0) {
|
||||||
|
fields.sort(Comparator.comparingDouble(commandField -> commandField.getField().getAnnotation(CommandRegister.class).priority()));
|
||||||
|
fields.forEach(commandField -> {
|
||||||
|
try {
|
||||||
|
commandField.getField().setAccessible(true);
|
||||||
|
baseMainCommand.registerSubCommand((BaseSubCommand) commandField.getField().get(commandField.getParent().newInstance()));
|
||||||
|
} catch (Exception ignored) {
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (methods.size() + fields.size() > 0) {
|
||||||
|
TLocale.Logger.info("COMMANDS.INTERNAL.COMMAND-REGISTER", baseMainCommand.getRegisterCommand().getPlugin().getName(), baseMainCommand.getRegisterCommand().getName(), String.valueOf(methods.size() + fields.size()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -94,7 +105,7 @@ public abstract class BaseMainCommand implements IMainCommand, CommandExecutor,
|
|||||||
helpCommand(sender, label);
|
helpCommand(sender, label);
|
||||||
} else {
|
} else {
|
||||||
for (BaseSubCommand subCommand : subCommands) {
|
for (BaseSubCommand subCommand : subCommands) {
|
||||||
if (subCommand == null || !args[0].equalsIgnoreCase(subCommand.getLabel())) {
|
if (subCommand == null || !args[0].equalsIgnoreCase(subCommand.getLabel()) || !hasPermission(sender, subCommand)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (!isConfirmType(sender, subCommand.getType())) {
|
if (!isConfirmType(sender, subCommand.getType())) {
|
||||||
@ -113,7 +124,7 @@ public abstract class BaseMainCommand implements IMainCommand, CommandExecutor,
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
List<BaseSubCommand> commandCompute = subCommands.stream().filter(Objects::nonNull).sorted((b, a) -> Double.compare(StringUtils.similarDegree(args[0], a.getLabel()), StringUtils.similarDegree(args[0], b.getLabel()))).collect(Collectors.toList());
|
List<BaseSubCommand> commandCompute = subCommands.stream().filter(x -> x != null && hasPermission(sender, x)).sorted((b, a) -> Double.compare(StringUtils.similarDegree(args[0], a.getLabel()), StringUtils.similarDegree(args[0], b.getLabel()))).collect(Collectors.toList());
|
||||||
if (commandCompute.size() > 0) {
|
if (commandCompute.size() > 0) {
|
||||||
TLocale.sendTo(sender, "COMMANDS.INTERNAL.ERROR-COMMAND", args[0], commandCompute.get(0).getCommandString(label).trim());
|
TLocale.sendTo(sender, "COMMANDS.INTERNAL.ERROR-COMMAND", args[0], commandCompute.get(0).getCommandString(label).trim());
|
||||||
}
|
}
|
||||||
@ -125,7 +136,7 @@ public abstract class BaseMainCommand implements IMainCommand, CommandExecutor,
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<String> onTabComplete(CommandSender commandSender, Command command, String s, String[] args) {
|
public List<String> onTabComplete(CommandSender commandSender, Command command, String s, String[] args) {
|
||||||
return args.length == 1 ? subCommands.stream().filter(internalCommandExecutor -> internalCommandExecutor != null && (args[0].isEmpty() || internalCommandExecutor.getLabel().toLowerCase().startsWith(args[0].toLowerCase()))).map(ISubCommand::getLabel).collect(Collectors.toList()) : null;
|
return args.length == 1 ? subCommands.stream().filter(subCommand -> subCommand != null && hasPermission(commandSender, subCommand) && (args[0].isEmpty() || subCommand.getLabel().toLowerCase().startsWith(args[0].toLowerCase()))).map(ISubCommand::getLabel).collect(Collectors.toList()) : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -162,7 +173,7 @@ public abstract class BaseMainCommand implements IMainCommand, CommandExecutor,
|
|||||||
sender.sendMessage(getEmptyLine());
|
sender.sendMessage(getEmptyLine());
|
||||||
sender.sendMessage(getCommandTitle());
|
sender.sendMessage(getCommandTitle());
|
||||||
sender.sendMessage(getEmptyLine());
|
sender.sendMessage(getEmptyLine());
|
||||||
subCommands.stream().map(subCommand -> subCommand == null ? getEmptyLine() : subCommand.getCommandString(label)).forEach(sender::sendMessage);
|
subCommands.stream().filter(subCommands -> hasPermission(sender, subCommands)).map(subCommand -> subCommand == null ? getEmptyLine() : subCommand.getCommandString(label)).forEach(sender::sendMessage);
|
||||||
sender.sendMessage(getEmptyLine());
|
sender.sendMessage(getEmptyLine());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -178,4 +189,8 @@ public abstract class BaseMainCommand implements IMainCommand, CommandExecutor,
|
|||||||
} catch (Exception ignored) {
|
} catch (Exception ignored) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean hasPermission(CommandSender sender, BaseSubCommand baseSubCommand) {
|
||||||
|
return baseSubCommand == null || baseSubCommand.getPermission() == null || sender.hasPermission(baseSubCommand.getPermission());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,10 @@
|
|||||||
package me.skymc.taboolib.commands.internal;
|
package me.skymc.taboolib.commands.internal;
|
||||||
|
|
||||||
import me.skymc.taboolib.commands.internal.type.CommandArgument;
|
import com.ilummc.tlib.resources.TLocale;
|
||||||
import me.skymc.taboolib.commands.internal.type.CommandType;
|
import me.skymc.taboolib.commands.internal.type.CommandType;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
import java.util.stream.IntStream;
|
import java.util.stream.IntStream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -23,23 +25,16 @@ public abstract class BaseSubCommand implements ISubCommand {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getPermission() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean isParameterConform(String[] args) {
|
public boolean isParameterConform(String[] args) {
|
||||||
return IntStream.range(0, getArguments().length).noneMatch(i -> getArguments()[i].isRequired() && (args == null || args.length <= i));
|
return IntStream.range(0, getArguments().length).noneMatch(i -> getArguments()[i].isRequired() && (args == null || args.length <= i));
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getCommandString(String label) {
|
public String getCommandString(String label) {
|
||||||
StringBuilder stringBuilder = new StringBuilder();
|
String stringBuilder = Arrays.stream(getArguments()).map(parameter -> parameter.toString() + " ").collect(Collectors.joining());
|
||||||
stringBuilder.append(" §f/");
|
return TLocale.asString("COMMANDS.INTERNAL.COMMAND-HELP", label, getLabel(), stringBuilder.trim(), getDescription());
|
||||||
stringBuilder.append(label);
|
|
||||||
stringBuilder.append(" ");
|
|
||||||
stringBuilder.append(getLabel());
|
|
||||||
stringBuilder.append(" ");
|
|
||||||
for (CommandArgument parameter : getArguments()) {
|
|
||||||
stringBuilder.append(parameter.toString());
|
|
||||||
stringBuilder.append(" ");
|
|
||||||
}
|
|
||||||
stringBuilder.append("§6- §e");
|
|
||||||
stringBuilder.append(getDescription());
|
|
||||||
return stringBuilder.toString();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -0,0 +1,19 @@
|
|||||||
|
package me.skymc.taboolib.commands.internal;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author sky
|
||||||
|
* @Since 2018-05-23 2:43
|
||||||
|
*/
|
||||||
|
public class TBaseCommand {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 向服务端注册 BaseMainCommand 类
|
||||||
|
*
|
||||||
|
* @param command 命令全称(需在 plugin.yml 内注册)
|
||||||
|
* @param baseMainCommand 命令对象
|
||||||
|
* @return {@link BaseMainCommand}
|
||||||
|
*/
|
||||||
|
public static BaseMainCommand registerCommand(String command, BaseMainCommand baseMainCommand) {
|
||||||
|
return BaseMainCommand.createCommandExecutor(command, baseMainCommand);
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,7 @@
|
|||||||
package me.skymc.taboolib.commands.internal.type;
|
package me.skymc.taboolib.commands.internal.type;
|
||||||
|
|
||||||
|
import com.ilummc.tlib.resources.TLocale;
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -30,7 +32,7 @@ public class CommandArgument {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return required ? "§7[§8" + name + "§7]" : "§7<§8" + name + "§7>";
|
return required ? TLocale.asString("COMMANDS.INTERNAL.COMMAND-ARGUMENT-REQUIRE", name) : TLocale.asString("COMMANDS.INTERNAL.COMMAND-ARGUMENT", name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -0,0 +1,26 @@
|
|||||||
|
package me.skymc.taboolib.commands.internal.type;
|
||||||
|
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author sky
|
||||||
|
* @Since 2018-05-23 3:07
|
||||||
|
*/
|
||||||
|
public class CommandField {
|
||||||
|
|
||||||
|
private final Field field;
|
||||||
|
private final Class<?> parent;
|
||||||
|
|
||||||
|
public CommandField(Field field, Class<?> parent) {
|
||||||
|
this.field = field;
|
||||||
|
this.parent = parent;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Field getField() {
|
||||||
|
return field;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Class<?> getParent() {
|
||||||
|
return parent;
|
||||||
|
}
|
||||||
|
}
|
@ -9,7 +9,7 @@ import java.lang.annotation.Target;
|
|||||||
* @Author sky
|
* @Author sky
|
||||||
* @Since 2018-05-09 22:38
|
* @Since 2018-05-09 22:38
|
||||||
*/
|
*/
|
||||||
@Target(ElementType.METHOD)
|
@Target({ElementType.METHOD, ElementType.FIELD})
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
public @interface CommandRegister {
|
public @interface CommandRegister {
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@ import me.skymc.taboolib.commands.internal.BaseMainCommand;
|
|||||||
import me.skymc.taboolib.commands.internal.BaseSubCommand;
|
import me.skymc.taboolib.commands.internal.BaseSubCommand;
|
||||||
import me.skymc.taboolib.commands.internal.ISubCommand;
|
import me.skymc.taboolib.commands.internal.ISubCommand;
|
||||||
import me.skymc.taboolib.commands.internal.type.CommandArgument;
|
import me.skymc.taboolib.commands.internal.type.CommandArgument;
|
||||||
|
import me.skymc.taboolib.commands.internal.type.CommandRegister;
|
||||||
import me.skymc.taboolib.plugin.PluginUtils;
|
import me.skymc.taboolib.plugin.PluginUtils;
|
||||||
import me.skymc.taboolib.string.ArrayUtils;
|
import me.skymc.taboolib.string.ArrayUtils;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
@ -13,7 +14,6 @@ import org.bukkit.command.Command;
|
|||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
@ -24,12 +24,9 @@ import java.util.stream.Collectors;
|
|||||||
*/
|
*/
|
||||||
public class TabooLibPluginMainCommand extends BaseMainCommand {
|
public class TabooLibPluginMainCommand extends BaseMainCommand {
|
||||||
|
|
||||||
public TabooLibPluginMainCommand() {
|
@Override
|
||||||
listCommand();
|
public String getCommandTitle() {
|
||||||
infoCommand();
|
return TLocale.asString("COMMANDS.TPLUGIN.COMMAND-TITLE");
|
||||||
loadCommand();
|
|
||||||
unloadCommand();
|
|
||||||
reloadCommand();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -43,17 +40,8 @@ public class TabooLibPluginMainCommand extends BaseMainCommand {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isPluginCommand(String label) {
|
@CommandRegister(priority = 1)
|
||||||
return "info".equalsIgnoreCase(label) || "load".equalsIgnoreCase(label) || "unload".equalsIgnoreCase(label) || "reload".equalsIgnoreCase(label);
|
BaseSubCommand load = new BaseSubCommand() {
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getCommandTitle() {
|
|
||||||
return TLocale.asString("COMMANDS.TPLUGIN.COMMAND-TITLE");
|
|
||||||
}
|
|
||||||
|
|
||||||
void loadCommand() {
|
|
||||||
registerSubCommand(new BaseSubCommand() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -87,11 +75,10 @@ public class TabooLibPluginMainCommand extends BaseMainCommand {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
void unloadCommand() {
|
@CommandRegister(priority = 2)
|
||||||
registerSubCommand(new BaseSubCommand() {
|
BaseSubCommand unload = new BaseSubCommand() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -128,11 +115,10 @@ public class TabooLibPluginMainCommand extends BaseMainCommand {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
void reloadCommand() {
|
@CommandRegister(priority = 3)
|
||||||
registerSubCommand(new BaseSubCommand() {
|
BaseSubCommand reload = new BaseSubCommand() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -162,11 +148,10 @@ public class TabooLibPluginMainCommand extends BaseMainCommand {
|
|||||||
PluginUtils.reload(plugin);
|
PluginUtils.reload(plugin);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
void infoCommand() {
|
@CommandRegister(priority = 4)
|
||||||
registerSubCommand(new BaseSubCommand() {
|
BaseSubCommand info = new BaseSubCommand() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -206,11 +191,10 @@ public class TabooLibPluginMainCommand extends BaseMainCommand {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
|
|
||||||
void listCommand() {
|
@CommandRegister(priority = 5)
|
||||||
registerSubCommand(new BaseSubCommand() {
|
BaseSubCommand list = new BaseSubCommand() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getLabel() {
|
public String getLabel() {
|
||||||
@ -232,6 +216,15 @@ public class TabooLibPluginMainCommand extends BaseMainCommand {
|
|||||||
List<String> pluginList = Arrays.stream(Bukkit.getPluginManager().getPlugins()).map(Plugin::getName).sorted(String.CASE_INSENSITIVE_ORDER).collect(Collectors.toList());
|
List<String> pluginList = Arrays.stream(Bukkit.getPluginManager().getPlugins()).map(Plugin::getName).sorted(String.CASE_INSENSITIVE_ORDER).collect(Collectors.toList());
|
||||||
TLocale.sendTo(sender, "COMMANDS.TPLUGIN.LIST.LIST-PLUGIN", String.valueOf(Bukkit.getPluginManager().getPlugins().length), Joiner.on(", ").join(pluginList));
|
TLocale.sendTo(sender, "COMMANDS.TPLUGIN.LIST.LIST-PLUGIN", String.valueOf(Bukkit.getPluginManager().getPlugins().length), Joiner.on(", ").join(pluginList));
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
|
// *********************************
|
||||||
|
//
|
||||||
|
// Private Methods
|
||||||
|
//
|
||||||
|
// *********************************
|
||||||
|
|
||||||
|
private boolean isPluginCommand(String label) {
|
||||||
|
return "info".equalsIgnoreCase(label) || "load".equalsIgnoreCase(label) || "unload".equalsIgnoreCase(label) || "reload".equalsIgnoreCase(label);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -49,7 +49,7 @@ public class SaveCommand extends SubCommand {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ChatCatcher.call((Player) sender, new ChatCatcher.Catcher() {
|
ChatCatcher.call((Player) sender, new Catcher() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void cancel() {
|
public void cancel() {
|
||||||
|
@ -2,8 +2,7 @@ package me.skymc.taboolib.commands.taboolib;
|
|||||||
|
|
||||||
import com.ilummc.tlib.resources.TLocale;
|
import com.ilummc.tlib.resources.TLocale;
|
||||||
import me.skymc.taboolib.commands.SubCommand;
|
import me.skymc.taboolib.commands.SubCommand;
|
||||||
import me.skymc.taboolib.team.TagAPI;
|
import me.skymc.taboolib.itagapi.TagDataHandler;
|
||||||
import me.skymc.taboolib.team.TagManager;
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
@ -27,8 +26,7 @@ public class TagDeleteCommand extends SubCommand {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
TagManager.getInst().unloadData(player);
|
TagDataHandler.getHandler().reset(player);
|
||||||
TagAPI.removePlayerDisplayName(player);
|
|
||||||
|
|
||||||
if (sender instanceof Player) {
|
if (sender instanceof Player) {
|
||||||
TLocale.sendTo(sender, "COMMANDS.TABOOLIB.PLAYERTAG.SUCCESS-DELETE", args[1]);
|
TLocale.sendTo(sender, "COMMANDS.TABOOLIB.PLAYERTAG.SUCCESS-DELETE", args[1]);
|
||||||
|
@ -3,6 +3,7 @@ package me.skymc.taboolib.commands.taboolib;
|
|||||||
import com.ilummc.tlib.resources.TLocale;
|
import com.ilummc.tlib.resources.TLocale;
|
||||||
import me.clip.placeholderapi.PlaceholderAPI;
|
import me.clip.placeholderapi.PlaceholderAPI;
|
||||||
import me.skymc.taboolib.commands.SubCommand;
|
import me.skymc.taboolib.commands.SubCommand;
|
||||||
|
import me.skymc.taboolib.itagapi.TagDataHandler;
|
||||||
import me.skymc.taboolib.team.TagAPI;
|
import me.skymc.taboolib.team.TagAPI;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
@ -27,12 +28,9 @@ public class TagDisplayCommand extends SubCommand {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
String value = getArgs(2).replace("&", "§");
|
String value = TLocale.Translate.setPlaceholders(player, getArgs(2));
|
||||||
if (Bukkit.getPluginManager().getPlugin("PlaceholderAPI") != null) {
|
TagDataHandler.getHandler().setDisplay(player, value);
|
||||||
value = PlaceholderAPI.setPlaceholders(player, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
TagAPI.setPlayerDisplayName(player, value);
|
|
||||||
if (sender instanceof Player) {
|
if (sender instanceof Player) {
|
||||||
TLocale.sendTo(sender, "COMMANDS.TABOOLIB.PLAYERTAG.SUCCESS-DISPLAY-SET", args[1], value);
|
TLocale.sendTo(sender, "COMMANDS.TABOOLIB.PLAYERTAG.SUCCESS-DISPLAY-SET", args[1], value);
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
package me.skymc.taboolib.commands.taboolib;
|
package me.skymc.taboolib.commands.taboolib;
|
||||||
|
|
||||||
import com.ilummc.tlib.resources.TLocale;
|
import com.ilummc.tlib.resources.TLocale;
|
||||||
import me.clip.placeholderapi.PlaceholderAPI;
|
|
||||||
import me.skymc.taboolib.commands.SubCommand;
|
import me.skymc.taboolib.commands.SubCommand;
|
||||||
import me.skymc.taboolib.team.TagManager;
|
import me.skymc.taboolib.itagapi.TagDataHandler;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
@ -27,12 +26,9 @@ public class TagPrefixCommand extends SubCommand {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
String value = getArgs(2).replace("&", "§");
|
String value = TLocale.Translate.setPlaceholders(player, getArgs(2));
|
||||||
if (Bukkit.getPluginManager().getPlugin("PlaceholderAPI") != null) {
|
TagDataHandler.getHandler().setPrefix(player, value);
|
||||||
value = PlaceholderAPI.setPlaceholders(player, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
TagManager.getInst().setPrefix(player, value);
|
|
||||||
if (sender instanceof Player) {
|
if (sender instanceof Player) {
|
||||||
TLocale.sendTo(sender, "COMMANDS.TABOOLIB.PLAYERTAG.SUCCESS-PREFIX-SET", args[1], value);
|
TLocale.sendTo(sender, "COMMANDS.TABOOLIB.PLAYERTAG.SUCCESS-PREFIX-SET", args[1], value);
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
package me.skymc.taboolib.commands.taboolib;
|
package me.skymc.taboolib.commands.taboolib;
|
||||||
|
|
||||||
import com.ilummc.tlib.resources.TLocale;
|
import com.ilummc.tlib.resources.TLocale;
|
||||||
import me.clip.placeholderapi.PlaceholderAPI;
|
|
||||||
import me.skymc.taboolib.commands.SubCommand;
|
import me.skymc.taboolib.commands.SubCommand;
|
||||||
import me.skymc.taboolib.team.TagManager;
|
import me.skymc.taboolib.itagapi.TagDataHandler;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
@ -27,12 +26,9 @@ public class TagSuffixCommand extends SubCommand {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
String value = getArgs(2).replace("&", "§");
|
String value = TLocale.Translate.setPlaceholders(player, getArgs(2));
|
||||||
if (Bukkit.getPluginManager().getPlugin("PlaceholderAPI") != null) {
|
TagDataHandler.getHandler().setSuffix(player, value);
|
||||||
value = PlaceholderAPI.setPlaceholders(player, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
TagManager.getInst().setSuffix(player, value);
|
|
||||||
if (sender instanceof Player) {
|
if (sender instanceof Player) {
|
||||||
TLocale.sendTo(sender, "COMMANDS.TABOOLIB.PLAYERTAG.SUCCESS-SUFFIX-SET", args[1], value);
|
TLocale.sendTo(sender, "COMMANDS.TABOOLIB.PLAYERTAG.SUCCESS-SUFFIX-SET", args[1], value);
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
package me.skymc.taboolib.inventory;
|
package me.skymc.taboolib.inventory;
|
||||||
|
|
||||||
import com.ilummc.tlib.resources.TLocale;
|
import lombok.Getter;
|
||||||
import me.clip.placeholderapi.PlaceholderAPI;
|
import me.clip.placeholderapi.PlaceholderAPI;
|
||||||
import me.skymc.taboolib.Main;
|
import me.skymc.taboolib.Main;
|
||||||
import me.skymc.taboolib.TabooLib;
|
import me.skymc.taboolib.TabooLib;
|
||||||
@ -9,6 +9,7 @@ import me.skymc.taboolib.itemnbtapi.NBTItem;
|
|||||||
import me.skymc.taboolib.itemnbtapi.NBTList;
|
import me.skymc.taboolib.itemnbtapi.NBTList;
|
||||||
import me.skymc.taboolib.itemnbtapi.NBTListCompound;
|
import me.skymc.taboolib.itemnbtapi.NBTListCompound;
|
||||||
import me.skymc.taboolib.itemnbtapi.NBTType;
|
import me.skymc.taboolib.itemnbtapi.NBTType;
|
||||||
|
import me.skymc.taboolib.message.MsgUtils;
|
||||||
import me.skymc.taboolib.other.NumberUtils;
|
import me.skymc.taboolib.other.NumberUtils;
|
||||||
import me.skymc.taboolib.string.Language;
|
import me.skymc.taboolib.string.Language;
|
||||||
import org.bukkit.Color;
|
import org.bukkit.Color;
|
||||||
@ -28,50 +29,30 @@ import org.bukkit.potion.PotionEffect;
|
|||||||
import org.bukkit.potion.PotionEffectType;
|
import org.bukkit.potion.PotionEffectType;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.Arrays;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.stream.IntStream;
|
|
||||||
|
|
||||||
public class ItemUtils {
|
public class ItemUtils {
|
||||||
|
|
||||||
|
@Getter
|
||||||
private static FileConfiguration itemdir = null;
|
private static FileConfiguration itemdir = null;
|
||||||
|
|
||||||
|
@Getter
|
||||||
private static FileConfiguration itemCache = null;
|
private static FileConfiguration itemCache = null;
|
||||||
|
|
||||||
|
@Getter
|
||||||
private static File finalItemsFolder;
|
private static File finalItemsFolder;
|
||||||
|
|
||||||
|
@Getter
|
||||||
private static LinkedHashMap<String, String> itemlib = new LinkedHashMap<>();
|
private static LinkedHashMap<String, String> itemlib = new LinkedHashMap<>();
|
||||||
|
|
||||||
|
@Getter
|
||||||
private static LinkedHashMap<String, ItemStack> itemCaches = new LinkedHashMap<>();
|
private static LinkedHashMap<String, ItemStack> itemCaches = new LinkedHashMap<>();
|
||||||
|
|
||||||
|
@Getter
|
||||||
private static LinkedHashMap<String, ItemStack> itemCachesFinal = new LinkedHashMap<>();
|
private static LinkedHashMap<String, ItemStack> itemCachesFinal = new LinkedHashMap<>();
|
||||||
|
|
||||||
public static FileConfiguration getItemdir() {
|
|
||||||
return itemdir;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static FileConfiguration getItemCache() {
|
|
||||||
return itemCache;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static File getFinalItemsFolder() {
|
|
||||||
return finalItemsFolder;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static LinkedHashMap<String, String> getItemlib() {
|
|
||||||
return itemlib;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static LinkedHashMap<String, ItemStack> getItemCaches() {
|
|
||||||
return itemCaches;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static LinkedHashMap<String, ItemStack> getItemCachesFinal() {
|
|
||||||
return itemCachesFinal;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取物品缓存
|
* 获取物品缓存
|
||||||
* 检测顺序:
|
* 检测顺序:
|
||||||
@ -100,7 +81,7 @@ public class ItemUtils {
|
|||||||
reloadItemCache();
|
reloadItemCache();
|
||||||
itemdir = YamlConfiguration.loadConfiguration(new File(Main.getInst().getConfig().getString("DATAURL.ITEMDIR")));
|
itemdir = YamlConfiguration.loadConfiguration(new File(Main.getInst().getConfig().getString("DATAURL.ITEMDIR")));
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
TLocale.Logger.error("ITEM-UTILS.FAIL-LOAD-ITEMS", e.toString());
|
MsgUtils.warn("物品库载入失败: &4" + e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -108,7 +89,7 @@ public class ItemUtils {
|
|||||||
FileConfiguration conf = ConfigUtils.load(Main.getInst(), file);
|
FileConfiguration conf = ConfigUtils.load(Main.getInst(), file);
|
||||||
for (String name : conf.getConfigurationSection("").getKeys(false)) {
|
for (String name : conf.getConfigurationSection("").getKeys(false)) {
|
||||||
if (isExists(name)) {
|
if (isExists(name)) {
|
||||||
TLocale.Logger.error("ITEM-UTILS.FAIL-LOAD-ITEMS", name);
|
MsgUtils.warn("无法载入载入物品 &4" + name + "&c, 因为它已经存在了");
|
||||||
} else if (finalFile) {
|
} else if (finalFile) {
|
||||||
itemCachesFinal.put(name, loadItem(conf, name));
|
itemCachesFinal.put(name, loadItem(conf, name));
|
||||||
} else {
|
} else {
|
||||||
@ -127,15 +108,19 @@ public class ItemUtils {
|
|||||||
finalItemsFolder.mkdir();
|
finalItemsFolder.mkdir();
|
||||||
}
|
}
|
||||||
// 检查固定物品库中的物品
|
// 检查固定物品库中的物品
|
||||||
Arrays.stream(finalItemsFolder.listFiles()).forEach(file -> loadItemsFile(file, true));
|
for (File file : finalItemsFolder.listFiles()) {
|
||||||
TLocale.Logger.info("ITEM-UTILS.SUCCESS-LOAD-CACHES", String.valueOf(itemCaches.size() + itemCachesFinal.size()));
|
loadItemsFile(file, true);
|
||||||
|
}
|
||||||
|
MsgUtils.send("载入 " + (itemCaches.size() + itemCachesFinal.size()) + " 项缓存物品");
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void reloadItemName() {
|
public static void reloadItemName() {
|
||||||
FileConfiguration conf = new Language("ITEM_NAME", Main.getInst(), true).getConfiguration();
|
FileConfiguration conf = new Language("ITEM_NAME", Main.getInst(), true).getConfiguration();
|
||||||
itemlib.clear();
|
itemlib.clear();
|
||||||
conf.getConfigurationSection("").getKeys(false).forEach(a -> itemlib.put(a, conf.getString(a)));
|
for (String a : conf.getConfigurationSection("").getKeys(false)) {
|
||||||
TLocale.Logger.info("ITEM-UTILS.SUCCESS-LOAD-NAMES", String.valueOf(itemlib.size()));
|
itemlib.put(a, conf.getString(a));
|
||||||
|
}
|
||||||
|
MsgUtils.send("载入 " + itemlib.size() + " 项物品名称");
|
||||||
}
|
}
|
||||||
|
|
||||||
public static File getItemCacheFile() {
|
public static File getItemCacheFile() {
|
||||||
@ -148,7 +133,7 @@ public class ItemUtils {
|
|||||||
|
|
||||||
public static String getCustomName(ItemStack item) {
|
public static String getCustomName(ItemStack item) {
|
||||||
if (item == null || item.getType().equals(Material.AIR)) {
|
if (item == null || item.getType().equals(Material.AIR)) {
|
||||||
return TLocale.asString("ITEM-UTILS.EMPTY-ITEM");
|
return "空";
|
||||||
}
|
}
|
||||||
int data = item.getType().getMaxDurability() == 0 ? item.getDurability() : 0;
|
int data = item.getType().getMaxDurability() == 0 ? item.getDurability() : 0;
|
||||||
return item.getItemMeta().hasDisplayName() ? item.getItemMeta().getDisplayName() : itemlib.get(item.getType() + ":" + data) == null ? item.getType().toString() : itemlib.get(item.getType() + ":" + data);
|
return item.getItemMeta().hasDisplayName() ? item.getItemMeta().getDisplayName() : itemlib.get(item.getType() + ":" + data) == null ? item.getType().toString() : itemlib.get(item.getType() + ":" + data);
|
||||||
@ -207,14 +192,17 @@ public class ItemUtils {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static List<String> asString(List<String> args, Player placeholderPlayer) {
|
public static List<String> asString(List<String> args, Player placeholderPlayer) {
|
||||||
IntStream.range(0, args.size()).forEach(i -> args.set(i, asString(args.get(i), placeholderPlayer)));
|
for (int i = 0 ; i < args.size() ; i ++) {
|
||||||
|
args.set(i, asString(args.get(i), placeholderPlayer));
|
||||||
|
}
|
||||||
return args;
|
return args;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ItemFlag asItemFlag(String flag) {
|
public static ItemFlag asItemFlag(String flag) {
|
||||||
try {
|
try {
|
||||||
return ItemFlag.valueOf(flag);
|
return ItemFlag.valueOf(flag);
|
||||||
} catch (Exception e) {
|
}
|
||||||
|
catch (Exception e) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -224,7 +212,8 @@ public class ItemUtils {
|
|||||||
try {
|
try {
|
||||||
Material material = Material.getMaterial(args);
|
Material material = Material.getMaterial(args);
|
||||||
return material != null ? material : Material.getMaterial(Integer.valueOf(args));
|
return material != null ? material : Material.getMaterial(Integer.valueOf(args));
|
||||||
} catch (Exception e) {
|
}
|
||||||
|
catch (Exception e) {
|
||||||
return Material.STONE;
|
return Material.STONE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -234,7 +223,8 @@ public class ItemUtils {
|
|||||||
try {
|
try {
|
||||||
Enchantment enchantment = Enchantment.getByName(enchant);
|
Enchantment enchantment = Enchantment.getByName(enchant);
|
||||||
return enchantment != null ? enchantment : Enchantment.getById(Integer.valueOf(enchant));
|
return enchantment != null ? enchantment : Enchantment.getById(Integer.valueOf(enchant));
|
||||||
} catch (Exception e) {
|
}
|
||||||
|
catch (Exception e) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -244,7 +234,8 @@ public class ItemUtils {
|
|||||||
try {
|
try {
|
||||||
PotionEffectType type = PotionEffectType.getByName(potion);
|
PotionEffectType type = PotionEffectType.getByName(potion);
|
||||||
return type != null ? type : PotionEffectType.getById(Integer.valueOf(potion));
|
return type != null ? type : PotionEffectType.getById(Integer.valueOf(potion));
|
||||||
} catch (Exception e) {
|
}
|
||||||
|
catch (Exception e) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -252,7 +243,8 @@ public class ItemUtils {
|
|||||||
public static Color asColor(String color) {
|
public static Color asColor(String color) {
|
||||||
try {
|
try {
|
||||||
return Color.fromBGR(Integer.valueOf(color.split("-")[0]), Integer.valueOf(color.split("-")[1]), Integer.valueOf(color.split("-")[2]));
|
return Color.fromBGR(Integer.valueOf(color.split("-")[0]), Integer.valueOf(color.split("-")[1]), Integer.valueOf(color.split("-")[2]));
|
||||||
} catch (Exception e) {
|
}
|
||||||
|
catch (Exception e) {
|
||||||
return Color.fromBGR(0, 0, 0);
|
return Color.fromBGR(0, 0, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -273,9 +265,8 @@ public class ItemUtils {
|
|||||||
return "generic.armor";
|
return "generic.armor";
|
||||||
case "luck":
|
case "luck":
|
||||||
return "generic.luck";
|
return "generic.luck";
|
||||||
default:
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -317,7 +308,7 @@ public class ItemUtils {
|
|||||||
public static ItemStack addLore(ItemStack is, String lore) {
|
public static ItemStack addLore(ItemStack is, String lore) {
|
||||||
ItemMeta meta = is.getItemMeta();
|
ItemMeta meta = is.getItemMeta();
|
||||||
|
|
||||||
List<String> _lore = meta.hasLore() ? meta.getLore() : Collections.emptyList();
|
List<String> _lore = meta.hasLore() ? meta.getLore() : new ArrayList<>();
|
||||||
_lore.add(lore.replaceAll("&", "§"));
|
_lore.add(lore.replaceAll("&", "§"));
|
||||||
|
|
||||||
is.setItemMeta(meta);
|
is.setItemMeta(meta);
|
||||||
@ -350,7 +341,14 @@ public class ItemUtils {
|
|||||||
* @param a 关键字
|
* @param a 关键字
|
||||||
*/
|
*/
|
||||||
public static int getLore(ItemStack i, String a) {
|
public static int getLore(ItemStack i, String a) {
|
||||||
return isLored(i) ? IntStream.range(0, i.getItemMeta().getLore().size()).filter(j -> i.getItemMeta().getLore().get(j).contains(a)).findFirst().orElse(0) : 0;
|
if (isLored(i)) {
|
||||||
|
for (int j = 0; j < i.getItemMeta().getLore().size() ; j++) {
|
||||||
|
if (i.getItemMeta().getLore().get(j).contains(a)) {
|
||||||
|
return j;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -379,10 +377,13 @@ public class ItemUtils {
|
|||||||
public static ItemStack repalceLore(ItemStack i, String l1, String l2) {
|
public static ItemStack repalceLore(ItemStack i, String l1, String l2) {
|
||||||
if (!isLored(i)) {
|
if (!isLored(i)) {
|
||||||
return i;
|
return i;
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
ItemMeta meta = i.getItemMeta();
|
ItemMeta meta = i.getItemMeta();
|
||||||
List<String> lore = meta.getLore();
|
List<String> lore = meta.getLore();
|
||||||
IntStream.range(0, lore.size()).forEach(j -> lore.set(j, lore.get(j).replace(l1, l2)));
|
for (int j = 0 ; j < lore.size() ; j++) {
|
||||||
|
lore.set(j, lore.get(j).replace(l1, l2));
|
||||||
|
}
|
||||||
meta.setLore(lore);
|
meta.setLore(lore);
|
||||||
i.setItemMeta(meta);
|
i.setItemMeta(meta);
|
||||||
}
|
}
|
||||||
@ -423,8 +424,10 @@ public class ItemUtils {
|
|||||||
Enchantment enchant = asEnchantment(preEnchant);
|
Enchantment enchant = asEnchantment(preEnchant);
|
||||||
if (enchant != null) {
|
if (enchant != null) {
|
||||||
meta.addEnchant(enchant, section.getInt("enchants." + preEnchant), true);
|
meta.addEnchant(enchant, section.getInt("enchants." + preEnchant), true);
|
||||||
} else {
|
}
|
||||||
TLocale.Logger.error("ITEM-UTILS.FAIL-LOAD-ENCHANTS", preEnchant);
|
else {
|
||||||
|
MsgUtils.warn("&8" + preEnchant + " &c不是一个有效的附魔名称");
|
||||||
|
MsgUtils.warn("&c输入 &4/taboolib enchants&c 查看所有附魔");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -434,8 +437,10 @@ public class ItemUtils {
|
|||||||
ItemFlag flag = asItemFlag(preFlag);
|
ItemFlag flag = asItemFlag(preFlag);
|
||||||
if (flag != null) {
|
if (flag != null) {
|
||||||
meta.addItemFlags(flag);
|
meta.addItemFlags(flag);
|
||||||
} else {
|
}
|
||||||
TLocale.Logger.error("ITEM-UTILS.FAIL-LOAD-FLAG", preFlag);
|
else {
|
||||||
|
MsgUtils.warn("&8" + preFlag + " &c不是一个有效的标签名称");
|
||||||
|
MsgUtils.warn("&c输入 &4/taboolib flags&c 查看所有标签");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -453,8 +458,10 @@ public class ItemUtils {
|
|||||||
potionEffectType,
|
potionEffectType,
|
||||||
NumberUtils.getInteger(section.getString("potions." + prePotionName).split("-")[0]),
|
NumberUtils.getInteger(section.getString("potions." + prePotionName).split("-")[0]),
|
||||||
NumberUtils.getInteger(section.getString("potions." + prePotionName).split("-")[1]) - 1), true);
|
NumberUtils.getInteger(section.getString("potions." + prePotionName).split("-")[1]) - 1), true);
|
||||||
} else {
|
}
|
||||||
TLocale.Logger.error("ITEM-UTILS.FAIL-LOAD-POTION", prePotionName);
|
else {
|
||||||
|
MsgUtils.warn("&8" + potionEffectType + " &c不是一个有效的药水名称");
|
||||||
|
MsgUtils.warn("&c输入 &4/taboolib potions&c 查看所有药水");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -468,13 +475,17 @@ public class ItemUtils {
|
|||||||
Object obj = section.get("nbt." + name);
|
Object obj = section.get("nbt." + name);
|
||||||
if (obj instanceof String) {
|
if (obj instanceof String) {
|
||||||
nbt.setString(name, obj.toString());
|
nbt.setString(name, obj.toString());
|
||||||
} else if (obj instanceof Double) {
|
}
|
||||||
|
else if (obj instanceof Double) {
|
||||||
nbt.setDouble(name, Double.valueOf(obj.toString()));
|
nbt.setDouble(name, Double.valueOf(obj.toString()));
|
||||||
} else if (obj instanceof Integer) {
|
}
|
||||||
|
else if (obj instanceof Integer) {
|
||||||
nbt.setInteger(name, Integer.valueOf(obj.toString()));
|
nbt.setInteger(name, Integer.valueOf(obj.toString()));
|
||||||
} else if (obj instanceof Long) {
|
}
|
||||||
|
else if (obj instanceof Long) {
|
||||||
nbt.setLong(name, Long.valueOf(obj.toString()));
|
nbt.setLong(name, Long.valueOf(obj.toString()));
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
nbt.setObject(name, obj);
|
nbt.setObject(name, obj);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -491,21 +502,26 @@ public class ItemUtils {
|
|||||||
if (num.toString().contains("%")) {
|
if (num.toString().contains("%")) {
|
||||||
_attr.setDouble("Amount", Double.valueOf(num.toString().replace("%", "")) / 100D);
|
_attr.setDouble("Amount", Double.valueOf(num.toString().replace("%", "")) / 100D);
|
||||||
_attr.setInteger("Operation", 1);
|
_attr.setInteger("Operation", 1);
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
_attr.setDouble("Amount", Double.valueOf(num.toString()));
|
_attr.setDouble("Amount", Double.valueOf(num.toString()));
|
||||||
_attr.setInteger("Operation", 0);
|
_attr.setInteger("Operation", 0);
|
||||||
}
|
}
|
||||||
_attr.setString("AttributeName", asAttribute(name));
|
_attr.setString("AttributeName", asAttribute(name));
|
||||||
_attr.setInteger("UUIDMost", NumberUtils.getRandom().nextInt(Integer.MAX_VALUE));
|
_attr.setInteger("UUIDMost", NumberUtils.getRand().nextInt(Integer.MAX_VALUE));
|
||||||
_attr.setInteger("UUIDLeast", NumberUtils.getRandom().nextInt(Integer.MAX_VALUE));
|
_attr.setInteger("UUIDLeast", NumberUtils.getRand().nextInt(Integer.MAX_VALUE));
|
||||||
_attr.setString("Name", asAttribute(name));
|
_attr.setString("Name", asAttribute(name));
|
||||||
if (!"all".equals(hand)) {
|
if (!hand.equals("all")) {
|
||||||
_attr.setString("Slot", hand);
|
_attr.setString("Slot", hand);
|
||||||
}
|
}
|
||||||
} catch (Exception ignored) {
|
|
||||||
}
|
}
|
||||||
} else {
|
catch (Exception e) {
|
||||||
TLocale.Logger.error("ITEM-UTILS.FAIL-LOAD-POTION", name);
|
MsgUtils.warn("&8" + name + " &c属性载入失败: &8" + e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
MsgUtils.warn("&8" + name + " &c不是一个有效的属性名称");
|
||||||
|
MsgUtils.warn("&c输入 &4/taboolib attributes&c 查看所有属性");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -530,21 +546,26 @@ public class ItemUtils {
|
|||||||
if (num.toString().contains("%")) {
|
if (num.toString().contains("%")) {
|
||||||
_attr.setDouble("Amount", Double.valueOf(num.toString().replace("%", "")) / 100D);
|
_attr.setDouble("Amount", Double.valueOf(num.toString().replace("%", "")) / 100D);
|
||||||
_attr.setInteger("Operation", 1);
|
_attr.setInteger("Operation", 1);
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
_attr.setDouble("Amount", Double.valueOf(num.toString()));
|
_attr.setDouble("Amount", Double.valueOf(num.toString()));
|
||||||
_attr.setInteger("Operation", 0);
|
_attr.setInteger("Operation", 0);
|
||||||
}
|
}
|
||||||
_attr.setString("AttributeName", asAttribute(name));
|
_attr.setString("AttributeName", asAttribute(name));
|
||||||
_attr.setInteger("UUIDMost", NumberUtils.getRandom().nextInt(Integer.MAX_VALUE));
|
_attr.setInteger("UUIDMost", NumberUtils.getRand().nextInt(Integer.MAX_VALUE));
|
||||||
_attr.setInteger("UUIDLeast", NumberUtils.getRandom().nextInt(Integer.MAX_VALUE));
|
_attr.setInteger("UUIDLeast", NumberUtils.getRand().nextInt(Integer.MAX_VALUE));
|
||||||
_attr.setString("Name", asAttribute(name));
|
_attr.setString("Name", asAttribute(name));
|
||||||
if (!"all".equals(hand)) {
|
if (!hand.equals("all")) {
|
||||||
_attr.setString("Slot", hand);
|
_attr.setString("Slot", hand);
|
||||||
}
|
}
|
||||||
} catch (NumberFormatException ignored) {
|
|
||||||
}
|
}
|
||||||
} else {
|
catch (Exception e) {
|
||||||
TLocale.Logger.error("ITEM-UTILS.FAIL-LOAD-POTION", name);
|
MsgUtils.warn("&8" + name + " &c属性载入失败: &8" + e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
MsgUtils.warn("&8" + name + " &c不是一个有效的属性名称");
|
||||||
|
MsgUtils.warn("&c输入 &4/taboolib attributes&c 查看所有属性");
|
||||||
}
|
}
|
||||||
return nbt;
|
return nbt;
|
||||||
}
|
}
|
||||||
|
191
src/main/java/me/skymc/taboolib/itagapi/TagDataHandler.java
Normal file
191
src/main/java/me/skymc/taboolib/itagapi/TagDataHandler.java
Normal file
@ -0,0 +1,191 @@
|
|||||||
|
package me.skymc.taboolib.itagapi;
|
||||||
|
|
||||||
|
import com.google.common.base.Preconditions;
|
||||||
|
import me.skymc.taboolib.Main;
|
||||||
|
import me.skymc.taboolib.packet.PacketUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.PlayerCommandPreprocessEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
import org.bukkit.plugin.Plugin;
|
||||||
|
import org.bukkit.scheduler.BukkitRunnable;
|
||||||
|
import org.bukkit.scoreboard.Scoreboard;
|
||||||
|
import org.bukkit.scoreboard.Team;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author sky
|
||||||
|
* @Since 2018-05-23 0:37
|
||||||
|
*/
|
||||||
|
public class TagDataHandler implements Listener {
|
||||||
|
|
||||||
|
private static TagDataHandler handler;
|
||||||
|
private HashMap<UUID, TagPlayerData> playersData = new HashMap<>();
|
||||||
|
|
||||||
|
public static void init(Plugin plugin) {
|
||||||
|
Preconditions.checkArgument(handler == null, "TagDataHandler is already instanced!");
|
||||||
|
handler = new TagDataHandler();
|
||||||
|
// 注册监听
|
||||||
|
Bukkit.getPluginManager().registerEvents(handler, plugin);
|
||||||
|
// 启动相关功能
|
||||||
|
new BukkitRunnable() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (PacketUtils.isProtocolLibEnabled()) {
|
||||||
|
TagPacket.inst();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}.runTask(plugin);
|
||||||
|
}
|
||||||
|
|
||||||
|
public TagPlayerData unregisterPlayerData(Player player) {
|
||||||
|
return playersData.remove(player.getUniqueId());
|
||||||
|
}
|
||||||
|
|
||||||
|
public TagPlayerData getPlayerData(Player player) {
|
||||||
|
return playersData.get(player.getUniqueId());
|
||||||
|
}
|
||||||
|
|
||||||
|
public TagPlayerData getPlayerDataComputeIfAbsent(Player player) {
|
||||||
|
return playersData.computeIfAbsent(player.getUniqueId(), x -> new TagPlayerData(player));
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPrefix(Player player) {
|
||||||
|
return getPlayerDataComputeIfAbsent(player).getPrefix();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getSuffix(Player player) {
|
||||||
|
return getPlayerDataComputeIfAbsent(player).getSuffix();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDisplay(Player player) {
|
||||||
|
return getPlayerDataComputeIfAbsent(player).getNameDisplay();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPrefix(Player player, String prefix) {
|
||||||
|
updatePlayerVariable(getPlayerDataComputeIfAbsent(player).setPrefix(prefix));
|
||||||
|
updatePlayerListName(player);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSuffix(Player player, String suffix) {
|
||||||
|
updatePlayerVariable(getPlayerDataComputeIfAbsent(player).setSuffix(suffix));
|
||||||
|
updatePlayerListName(player);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPrefixAndSuffix(Player player, String prefix, String suffix) {
|
||||||
|
updatePlayerVariable(getPlayerDataComputeIfAbsent(player).setPrefix(prefix).setSuffix(suffix));
|
||||||
|
updatePlayerListName(player);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDisplay(Player player, String display) {
|
||||||
|
TagPlayerData playerData = getPlayerDataComputeIfAbsent(player);
|
||||||
|
cancelPlayerVariable(player, playerData);
|
||||||
|
player.setDisplayName(playerData.setNameDisplay(display).getNameDisplay());
|
||||||
|
updatePlayerVariable(playerData);
|
||||||
|
updatePlayerListName(player);
|
||||||
|
Bukkit.getScheduler().runTask(Main.getInst(), () -> TagPacket.refreshPlayer(player));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void resetVariable(Player player) {
|
||||||
|
updatePlayerVariable(getPlayerDataComputeIfAbsent(player).reset());
|
||||||
|
updatePlayerListName(player);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void resetDisplay(Player player) {
|
||||||
|
setDisplay(player, player.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
public void reset(Player player) {
|
||||||
|
updatePlayerVariable(getPlayerDataComputeIfAbsent(player).reset());
|
||||||
|
setDisplay(player, player.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
// *********************************
|
||||||
|
//
|
||||||
|
// Private Methods
|
||||||
|
//
|
||||||
|
// *********************************
|
||||||
|
|
||||||
|
private void downloadPlayerVariable(Player player) {
|
||||||
|
Scoreboard scoreboard = TagUtils.getScoreboardComputeIfAbsent(player);
|
||||||
|
playersData.values().forEach(playerData -> updateTeamVariable(scoreboard, playerData));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updatePlayerVariable(TagPlayerData playerData) {
|
||||||
|
Bukkit.getOnlinePlayers().forEach(online -> updateTeamVariable(TagUtils.getScoreboardComputeIfAbsent(online), playerData));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updatePlayerListName(Player player) {
|
||||||
|
TagPlayerData playerData = getPlayerDataComputeIfAbsent(player);
|
||||||
|
player.setPlayerListName(!playerData.getNameDisplay().equals(player.getName()) ? playerData.getPrefix() + playerData.getNameDisplay() + playerData.getSuffix() : playerData.getNameDisplay());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateTeamVariable(Scoreboard scoreboard, TagPlayerData playerData) {
|
||||||
|
Team entryTeam = TagUtils.getTeamComputeIfAbsent(scoreboard, playerData.getTeamHash());
|
||||||
|
entryTeam.addEntry(playerData.getNameDisplay());
|
||||||
|
entryTeam.setPrefix(playerData.getPrefix());
|
||||||
|
entryTeam.setSuffix(playerData.getSuffix());
|
||||||
|
TagUtils.cleanEmptyTeamInScoreboard(scoreboard);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void cancelPlayerVariable(Player player, TagPlayerData playerData) {
|
||||||
|
if (playerData == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (Player online : Bukkit.getOnlinePlayers()) {
|
||||||
|
Scoreboard scoreboard = TagUtils.getScoreboardComputeIfAbsent(player);
|
||||||
|
TagUtils.cleanEntryInScoreboard(scoreboard, playerData.getNameDisplay());
|
||||||
|
TagUtils.cleanEmptyTeamInScoreboard(scoreboard);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// *********************************
|
||||||
|
//
|
||||||
|
// Listeners
|
||||||
|
//
|
||||||
|
// *********************************
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onJoin(PlayerJoinEvent e) {
|
||||||
|
downloadPlayerVariable(e.getPlayer());
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onQuit(PlayerQuitEvent e) {
|
||||||
|
cancelPlayerVariable(e.getPlayer(), unregisterPlayerData(e.getPlayer()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onCommand(PlayerCommandPreprocessEvent e) {
|
||||||
|
if (e.getMessage().equalsIgnoreCase("/scoreboardinfo") && e.getPlayer().hasPermission("itagapi.info")) {
|
||||||
|
e.setCancelled(true);
|
||||||
|
|
||||||
|
e.getPlayer().sendMessage("§7计分板信息:");
|
||||||
|
Scoreboard scoreboard = TagUtils.getScoreboardComputeIfAbsent(e.getPlayer());
|
||||||
|
|
||||||
|
for (Team team : scoreboard.getTeams()) {
|
||||||
|
e.getPlayer().sendMessage("§7队伍: §f" + team.getName());
|
||||||
|
e.getPlayer().sendMessage("§f - §7前缀: §f" + team.getPrefix());
|
||||||
|
e.getPlayer().sendMessage("§f - §7后缀: §f" + team.getSuffix());
|
||||||
|
e.getPlayer().sendMessage("§f - §7成员: §f");
|
||||||
|
team.getEntries().forEach(entry -> e.getPlayer().sendMessage("§f - §f" + entry));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// *********************************
|
||||||
|
//
|
||||||
|
// Getter and Setter
|
||||||
|
//
|
||||||
|
// *********************************
|
||||||
|
|
||||||
|
public static TagDataHandler getHandler() {
|
||||||
|
return handler;
|
||||||
|
}
|
||||||
|
}
|
136
src/main/java/me/skymc/taboolib/itagapi/TagPacket.java
Normal file
136
src/main/java/me/skymc/taboolib/itagapi/TagPacket.java
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
package me.skymc.taboolib.itagapi;
|
||||||
|
|
||||||
|
import com.comphenix.protocol.PacketType;
|
||||||
|
import com.comphenix.protocol.ProtocolLibrary;
|
||||||
|
import com.comphenix.protocol.events.PacketAdapter;
|
||||||
|
import com.comphenix.protocol.events.PacketEvent;
|
||||||
|
import com.comphenix.protocol.wrappers.EnumWrappers;
|
||||||
|
import com.comphenix.protocol.wrappers.PlayerInfoData;
|
||||||
|
import com.comphenix.protocol.wrappers.WrappedGameProfile;
|
||||||
|
import com.google.common.base.Preconditions;
|
||||||
|
import me.skymc.taboolib.Main;
|
||||||
|
import me.skymc.taboolib.events.itag.AsyncPlayerReceiveNameTagEvent;
|
||||||
|
import me.skymc.taboolib.events.itag.PlayerReceiveNameTagEvent;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.stream.IntStream;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author sky
|
||||||
|
* @Since 2018-05-09 21:03
|
||||||
|
*/
|
||||||
|
class TagPacket implements Listener {
|
||||||
|
|
||||||
|
private static final int[] uuidSplit = new int[]{0, 8, 12, 16, 20, 32};
|
||||||
|
|
||||||
|
private static boolean loaded = false;
|
||||||
|
private static HashMap<Integer, Player> entityIdMap = new HashMap<>();
|
||||||
|
|
||||||
|
TagPacket() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void inst() {
|
||||||
|
assert !loaded : "TagAPI is already instanced!";
|
||||||
|
loaded = true;
|
||||||
|
|
||||||
|
Bukkit.getServer().getOnlinePlayers().forEach(player -> entityIdMap.put(player.getEntityId(), player));
|
||||||
|
Bukkit.getPluginManager().registerEvents(new TagPacket(), Main.getInst());
|
||||||
|
ProtocolLibrary.getProtocolManager().addPacketListener(new PacketAdapter(Main.getInst(), PacketType.Play.Server.PLAYER_INFO) {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPacketSending(PacketEvent event) {
|
||||||
|
if (event.getPacket().getPlayerInfoAction().read(0) != EnumWrappers.PlayerInfoAction.ADD_PLAYER) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
List<PlayerInfoData> newPlayerInfo = new ArrayList<>();
|
||||||
|
for (PlayerInfoData playerInfo : event.getPacket().getPlayerInfoDataLists().read(0)) {
|
||||||
|
Player player;
|
||||||
|
if (playerInfo == null || playerInfo.getProfile() == null || (player = Bukkit.getServer().getPlayer(playerInfo.getProfile().getUUID())) == null) {
|
||||||
|
// Unknown Player
|
||||||
|
newPlayerInfo.add(playerInfo);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
newPlayerInfo.add(new PlayerInfoData(getSentName(player.getEntityId(), playerInfo.getProfile(), event.getPlayer()), playerInfo.getPing(), playerInfo.getGameMode(), playerInfo.getDisplayName()));
|
||||||
|
}
|
||||||
|
event.getPacket().getPlayerInfoDataLists().write(0, newPlayerInfo);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
static String getPlayerDisplayName(Player player) {
|
||||||
|
return TagDataHandler.getHandler().getPlayerDataComputeIfAbsent(player).getNameDisplay();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void refreshPlayer(Player player) {
|
||||||
|
Preconditions.checkState(Main.getInst().isEnabled(), "Not Enabled!");
|
||||||
|
Preconditions.checkNotNull(player, "player");
|
||||||
|
player.getWorld().getPlayers().forEach(playerFor -> refreshPlayer(player, playerFor));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void refreshPlayer(final Player player, final Player forWhom) {
|
||||||
|
Preconditions.checkState(Main.getInst().isEnabled(), "Not Enabled!");
|
||||||
|
Preconditions.checkNotNull(player, "player");
|
||||||
|
Preconditions.checkNotNull(forWhom, "forWhom");
|
||||||
|
|
||||||
|
if (player != forWhom && player.getWorld() == forWhom.getWorld() && forWhom.canSee(player)) {
|
||||||
|
forWhom.hidePlayer(player);
|
||||||
|
Bukkit.getServer().getScheduler().scheduleSyncDelayedTask(Main.getInst(), () -> forWhom.showPlayer(player), 2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void refreshPlayer(Player player, Set<Player> forWhom) {
|
||||||
|
Preconditions.checkState(Main.getInst().isEnabled(), "Not Enabled!");
|
||||||
|
Preconditions.checkNotNull(player, "player");
|
||||||
|
Preconditions.checkNotNull(forWhom, "forWhom");
|
||||||
|
|
||||||
|
forWhom.forEach(playerFor -> refreshPlayer(player, playerFor));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static WrappedGameProfile getSentName(int sentEntityId, WrappedGameProfile sent, Player destinationPlayer) {
|
||||||
|
Preconditions.checkState(Bukkit.getServer().isPrimaryThread(), "Can only process events on main thread.");
|
||||||
|
|
||||||
|
Player namedPlayer = entityIdMap.get(sentEntityId);
|
||||||
|
if (namedPlayer == null) {
|
||||||
|
// They probably were dead when we reloaded
|
||||||
|
return sent;
|
||||||
|
}
|
||||||
|
|
||||||
|
PlayerReceiveNameTagEvent oldEvent = new PlayerReceiveNameTagEvent(destinationPlayer, namedPlayer, sent.getName());
|
||||||
|
Bukkit.getServer().getPluginManager().callEvent(oldEvent);
|
||||||
|
|
||||||
|
StringBuilder builtUUID = new StringBuilder();
|
||||||
|
if (!sent.getId().contains("-")) {
|
||||||
|
IntStream.range(0, uuidSplit.length - 1).forEach(i -> builtUUID.append(sent.getId(), uuidSplit[i], uuidSplit[i + 1]).append("-"));
|
||||||
|
} else {
|
||||||
|
builtUUID.append(sent.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
AsyncPlayerReceiveNameTagEvent newEvent = new AsyncPlayerReceiveNameTagEvent(destinationPlayer, namedPlayer, getPlayerDisplayName(namedPlayer), UUID.fromString(builtUUID.toString()));
|
||||||
|
Bukkit.getServer().getPluginManager().callEvent(newEvent);
|
||||||
|
|
||||||
|
return new WrappedGameProfile(newEvent.getUUID(), newEvent.getTag().substring(0, Math.min(newEvent.getTag().length(), 16)));
|
||||||
|
}
|
||||||
|
|
||||||
|
// *********************************
|
||||||
|
//
|
||||||
|
// Listeners
|
||||||
|
//
|
||||||
|
// *********************************
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onJoin(PlayerJoinEvent event) {
|
||||||
|
entityIdMap.put(event.getPlayer().getEntityId(), event.getPlayer());
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onQuit(PlayerQuitEvent event) {
|
||||||
|
entityIdMap.remove(event.getPlayer().getEntityId());
|
||||||
|
}
|
||||||
|
}
|
84
src/main/java/me/skymc/taboolib/itagapi/TagPlayerData.java
Normal file
84
src/main/java/me/skymc/taboolib/itagapi/TagPlayerData.java
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
package me.skymc.taboolib.itagapi;
|
||||||
|
|
||||||
|
import com.ilummc.tlib.util.Strings;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author sky
|
||||||
|
* @Since 2018-05-21 15:07
|
||||||
|
*/
|
||||||
|
public class TagPlayerData {
|
||||||
|
|
||||||
|
private final UUID uuid;
|
||||||
|
private String nameDisplay;
|
||||||
|
private String prefix;
|
||||||
|
private String suffix;
|
||||||
|
|
||||||
|
public TagPlayerData(Player player) {
|
||||||
|
this.uuid = player.getUniqueId();
|
||||||
|
this.nameDisplay = player.getName();
|
||||||
|
this.prefix = "";
|
||||||
|
this.suffix = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getTeamHash() {
|
||||||
|
return String.valueOf(Objects.hash(prefix));
|
||||||
|
}
|
||||||
|
|
||||||
|
public TagPlayerData reset() {
|
||||||
|
this.nameDisplay = getNameOrigin();
|
||||||
|
this.prefix = "";
|
||||||
|
this.suffix = "";
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return Strings.replaceWithOrder("TagPlayerData'{'uuid={0}, nameDisplay=''{1}'', prefix=''{2}'', suffix=''{3}'''}'", uuid, nameDisplay, prefix, suffix);
|
||||||
|
}
|
||||||
|
|
||||||
|
// *********************************
|
||||||
|
//
|
||||||
|
// Getter and Setter
|
||||||
|
//
|
||||||
|
// *********************************
|
||||||
|
|
||||||
|
public UUID getUUID() {
|
||||||
|
return uuid;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getNameOrigin() {
|
||||||
|
return Bukkit.getPlayer(uuid).getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getNameDisplay() {
|
||||||
|
return nameDisplay == null ? "" : nameDisplay;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPrefix() {
|
||||||
|
return prefix == null ? "" : prefix;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getSuffix() {
|
||||||
|
return suffix == null ? "" : suffix;
|
||||||
|
}
|
||||||
|
|
||||||
|
public TagPlayerData setNameDisplay(String nameDisplay) {
|
||||||
|
this.nameDisplay = nameDisplay.length() > 16 ? nameDisplay.substring(0, 16) : nameDisplay;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public TagPlayerData setPrefix(String prefix) {
|
||||||
|
this.prefix = prefix.length() > 16 ? prefix.substring(0, 16) : prefix;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public TagPlayerData setSuffix(String suffix) {
|
||||||
|
this.suffix = suffix.length() > 16 ? suffix.substring(0, 16) : suffix;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}
|
62
src/main/java/me/skymc/taboolib/itagapi/TagUtils.java
Normal file
62
src/main/java/me/skymc/taboolib/itagapi/TagUtils.java
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
package me.skymc.taboolib.itagapi;
|
||||||
|
|
||||||
|
import com.ilummc.tlib.logger.TLogger;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.scoreboard.Scoreboard;
|
||||||
|
import org.bukkit.scoreboard.Team;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author sky
|
||||||
|
* @Since 2018-05-21 15:09
|
||||||
|
*/
|
||||||
|
public class TagUtils {
|
||||||
|
|
||||||
|
public static void cleanTeamInScoreboard(Scoreboard scoreboard) {
|
||||||
|
try {
|
||||||
|
scoreboard.getTeams().forEach(Team::unregister);
|
||||||
|
} catch (Exception e) {
|
||||||
|
TLogger.getGlobalLogger().error("TagUtils.cleanTeamInScoreboard() 异常: " + e.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void cleanEntryInScoreboard(Scoreboard scoreboard, String entry) {
|
||||||
|
try {
|
||||||
|
Optional.ofNullable(scoreboard.getEntryTeam(entry)).ifPresent(x -> x.removeEntry(entry));
|
||||||
|
} catch (Exception e) {
|
||||||
|
TLogger.getGlobalLogger().error("TagUtils.cleanEntryInScoreboard() 异常: " + e.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void cleanEmptyTeamInScoreboard(Scoreboard scoreboard) {
|
||||||
|
try {
|
||||||
|
scoreboard.getTeams().stream().filter(team -> team.getEntries().size() == 0).forEach(Team::unregister);
|
||||||
|
} catch (Exception e) {
|
||||||
|
TLogger.getGlobalLogger().error("TagUtils.cleanEmptyTeamInScoreboard() 异常: " + e.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Scoreboard getScoreboardComputeIfAbsent(Player player) {
|
||||||
|
Scoreboard scoreboard = player.getScoreboard();
|
||||||
|
if (scoreboard == null) {
|
||||||
|
player.setScoreboard(Bukkit.getScoreboardManager().getNewScoreboard());
|
||||||
|
}
|
||||||
|
return player.getScoreboard();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Scoreboard getScoreboardAndCleanTeams(Player player) {
|
||||||
|
Scoreboard scoreboard = getScoreboardComputeIfAbsent(player);
|
||||||
|
cleanTeamInScoreboard(scoreboard);
|
||||||
|
return scoreboard;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Team getTeamComputeIfAbsent(Scoreboard scoreboard, String teamName) {
|
||||||
|
Team team = scoreboard.getTeam(teamName);
|
||||||
|
if (team == null) {
|
||||||
|
scoreboard.registerNewTeam(teamName);
|
||||||
|
}
|
||||||
|
return scoreboard.getTeam(teamName);
|
||||||
|
}
|
||||||
|
}
|
@ -313,7 +313,7 @@ public class NMSUtil18 {
|
|||||||
class_NBTTagCompound_getByteMethod = class_NBTTagCompound.getMethod("getByte", String.class);
|
class_NBTTagCompound_getByteMethod = class_NBTTagCompound.getMethod("getByte", String.class);
|
||||||
class_NBTTagCompound_getByteArrayMethod = class_NBTTagCompound.getMethod("getByteArray", String.class);
|
class_NBTTagCompound_getByteArrayMethod = class_NBTTagCompound.getMethod("getByteArray", String.class);
|
||||||
class_NBTTagCompound_getListMethod = class_NBTTagCompound.getMethod("getList", String.class, Integer.TYPE);
|
class_NBTTagCompound_getListMethod = class_NBTTagCompound.getMethod("getList", String.class, Integer.TYPE);
|
||||||
class_CraftItemStack_copyMethod = class_CraftItemStack.getMethod("asNMSCopy", org.bukkit.inventory.ItemStack.class);
|
class_CraftItemStack_copyMethod = class_CraftItemStack.getMethod("asNMSCopy", ItemStack.class);
|
||||||
class_CraftItemStack_asBukkitCopyMethod = class_CraftItemStack.getMethod("asBukkitCopy", class_ItemStack);
|
class_CraftItemStack_asBukkitCopyMethod = class_CraftItemStack.getMethod("asBukkitCopy", class_ItemStack);
|
||||||
class_CraftItemStack_mirrorMethod = class_CraftItemStack.getMethod("asCraftMirror", class_ItemStack);
|
class_CraftItemStack_mirrorMethod = class_CraftItemStack.getMethod("asCraftMirror", class_ItemStack);
|
||||||
class_ItemStack_createStackMethod = class_ItemStack.getMethod("createStack", class_NBTTagCompound);
|
class_ItemStack_createStackMethod = class_ItemStack.getMethod("createStack", class_NBTTagCompound);
|
||||||
@ -526,7 +526,7 @@ public class NMSUtil18 {
|
|||||||
return NMSUtil18.class.getClassLoader().loadClass(className);
|
return NMSUtil18.class.getClassLoader().loadClass(className);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.inventory.ItemStack stack) {
|
public static Object getHandle(ItemStack stack) {
|
||||||
Object handle = null;
|
Object handle = null;
|
||||||
try {
|
try {
|
||||||
handle = class_CraftItemStack_getHandleField.get(stack);
|
handle = class_CraftItemStack_getHandleField.get(stack);
|
||||||
@ -536,7 +536,7 @@ public class NMSUtil18 {
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.World world) {
|
public static Object getHandle(World world) {
|
||||||
if (world == null) {
|
if (world == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -549,7 +549,7 @@ public class NMSUtil18 {
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.entity.Entity entity) {
|
public static Object getHandle(Entity entity) {
|
||||||
if (entity == null) {
|
if (entity == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -575,7 +575,7 @@ public class NMSUtil18 {
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isDone(org.bukkit.Chunk chunk) {
|
public static boolean isDone(Chunk chunk) {
|
||||||
Object chunkHandle = getHandle(chunk);
|
Object chunkHandle = getHandle(chunk);
|
||||||
boolean done = false;
|
boolean done = false;
|
||||||
try {
|
try {
|
||||||
@ -586,7 +586,7 @@ public class NMSUtil18 {
|
|||||||
return done;
|
return done;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.Chunk chunk) {
|
public static Object getHandle(Chunk chunk) {
|
||||||
Object handle = null;
|
Object handle = null;
|
||||||
try {
|
try {
|
||||||
handle = class_CraftChunk_getHandleMethod.invoke(chunk);
|
handle = class_CraftChunk_getHandleMethod.invoke(chunk);
|
||||||
@ -596,7 +596,7 @@ public class NMSUtil18 {
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.entity.Player player) {
|
public static Object getHandle(Player player) {
|
||||||
Object handle = null;
|
Object handle = null;
|
||||||
try {
|
try {
|
||||||
handle = class_CraftPlayer_getHandleMethod.invoke(player);
|
handle = class_CraftPlayer_getHandleMethod.invoke(player);
|
||||||
@ -652,17 +652,17 @@ public class NMSUtil18 {
|
|||||||
return dir;
|
return dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static org.bukkit.entity.Entity getBukkitEntity(Object entity) {
|
public static Entity getBukkitEntity(Object entity) {
|
||||||
if (entity == null) {
|
if (entity == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
Method getMethod = entity.getClass().getMethod("getBukkitEntity");
|
Method getMethod = entity.getClass().getMethod("getBukkitEntity");
|
||||||
Object bukkitEntity = getMethod.invoke(entity);
|
Object bukkitEntity = getMethod.invoke(entity);
|
||||||
if (!(bukkitEntity instanceof org.bukkit.entity.Entity)) {
|
if (!(bukkitEntity instanceof Entity)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return (org.bukkit.entity.Entity) bukkitEntity;
|
return (Entity) bukkitEntity;
|
||||||
} catch (Throwable ex) {
|
} catch (Throwable ex) {
|
||||||
ex.printStackTrace();
|
ex.printStackTrace();
|
||||||
}
|
}
|
||||||
|
@ -377,7 +377,7 @@ public class NMSUtil19 {
|
|||||||
class_NBTTagCompound_getByteMethod = class_NBTTagCompound.getMethod("getByte", String.class);
|
class_NBTTagCompound_getByteMethod = class_NBTTagCompound.getMethod("getByte", String.class);
|
||||||
class_NBTTagCompound_getByteArrayMethod = class_NBTTagCompound.getMethod("getByteArray", String.class);
|
class_NBTTagCompound_getByteArrayMethod = class_NBTTagCompound.getMethod("getByteArray", String.class);
|
||||||
class_NBTTagCompound_getListMethod = class_NBTTagCompound.getMethod("getList", String.class, Integer.TYPE);
|
class_NBTTagCompound_getListMethod = class_NBTTagCompound.getMethod("getList", String.class, Integer.TYPE);
|
||||||
class_CraftItemStack_copyMethod = class_CraftItemStack.getMethod("asNMSCopy", org.bukkit.inventory.ItemStack.class);
|
class_CraftItemStack_copyMethod = class_CraftItemStack.getMethod("asNMSCopy", ItemStack.class);
|
||||||
class_CraftItemStack_asBukkitCopyMethod = class_CraftItemStack.getMethod("asBukkitCopy", class_ItemStack);
|
class_CraftItemStack_asBukkitCopyMethod = class_CraftItemStack.getMethod("asBukkitCopy", class_ItemStack);
|
||||||
class_CraftItemStack_mirrorMethod = class_CraftItemStack.getMethod("asCraftMirror", class_ItemStack);
|
class_CraftItemStack_mirrorMethod = class_CraftItemStack.getMethod("asCraftMirror", class_ItemStack);
|
||||||
class_World_addEntityMethod = class_World.getMethod("addEntity", class_Entity, CreatureSpawnEvent.SpawnReason.class);
|
class_World_addEntityMethod = class_World.getMethod("addEntity", class_Entity, CreatureSpawnEvent.SpawnReason.class);
|
||||||
@ -931,7 +931,7 @@ public class NMSUtil19 {
|
|||||||
return NMSUtils.class.getClassLoader().loadClass(className);
|
return NMSUtils.class.getClassLoader().loadClass(className);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.Server server) {
|
public static Object getHandle(Server server) {
|
||||||
Object handle = null;
|
Object handle = null;
|
||||||
try {
|
try {
|
||||||
handle = class_CraftServer_getServerMethod.invoke(server);
|
handle = class_CraftServer_getServerMethod.invoke(server);
|
||||||
@ -941,7 +941,7 @@ public class NMSUtil19 {
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.inventory.ItemStack stack) {
|
public static Object getHandle(ItemStack stack) {
|
||||||
Object handle = null;
|
Object handle = null;
|
||||||
try {
|
try {
|
||||||
handle = class_CraftItemStack_getHandleField.get(stack);
|
handle = class_CraftItemStack_getHandleField.get(stack);
|
||||||
@ -951,7 +951,7 @@ public class NMSUtil19 {
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.World world) {
|
public static Object getHandle(World world) {
|
||||||
if (world == null) {
|
if (world == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -964,7 +964,7 @@ public class NMSUtil19 {
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.entity.Entity entity) {
|
public static Object getHandle(Entity entity) {
|
||||||
if (entity == null) {
|
if (entity == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -990,7 +990,7 @@ public class NMSUtil19 {
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isDone(org.bukkit.Chunk chunk) {
|
public static boolean isDone(Chunk chunk) {
|
||||||
Object chunkHandle = getHandle(chunk);
|
Object chunkHandle = getHandle(chunk);
|
||||||
boolean done = false;
|
boolean done = false;
|
||||||
try {
|
try {
|
||||||
@ -1001,7 +1001,7 @@ public class NMSUtil19 {
|
|||||||
return done;
|
return done;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.Chunk chunk) {
|
public static Object getHandle(Chunk chunk) {
|
||||||
Object handle = null;
|
Object handle = null;
|
||||||
try {
|
try {
|
||||||
handle = class_CraftChunk_getHandleMethod.invoke(chunk);
|
handle = class_CraftChunk_getHandleMethod.invoke(chunk);
|
||||||
@ -1011,7 +1011,7 @@ public class NMSUtil19 {
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object getHandle(org.bukkit.entity.Player player) {
|
public static Object getHandle(Player player) {
|
||||||
Object handle = null;
|
Object handle = null;
|
||||||
try {
|
try {
|
||||||
handle = class_CraftPlayer_getHandleMethod.invoke(player);
|
handle = class_CraftPlayer_getHandleMethod.invoke(player);
|
||||||
@ -1068,7 +1068,7 @@ public class NMSUtil19 {
|
|||||||
return dir;
|
return dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static org.bukkit.entity.Entity getBukkitEntity(Object entity)
|
public static Entity getBukkitEntity(Object entity)
|
||||||
{
|
{
|
||||||
if (entity == null) {
|
if (entity == null) {
|
||||||
return null;
|
return null;
|
||||||
@ -1076,10 +1076,10 @@ public class NMSUtil19 {
|
|||||||
try {
|
try {
|
||||||
Method getMethod = entity.getClass().getMethod("getBukkitEntity");
|
Method getMethod = entity.getClass().getMethod("getBukkitEntity");
|
||||||
Object bukkitEntity = getMethod.invoke(entity);
|
Object bukkitEntity = getMethod.invoke(entity);
|
||||||
if (!(bukkitEntity instanceof org.bukkit.entity.Entity)) {
|
if (!(bukkitEntity instanceof Entity)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return (org.bukkit.entity.Entity)bukkitEntity;
|
return (Entity)bukkitEntity;
|
||||||
} catch (Throwable ex) {
|
} catch (Throwable ex) {
|
||||||
ex.printStackTrace();
|
ex.printStackTrace();
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,9 @@
|
|||||||
package me.skymc.taboolib.string.language2;
|
package me.skymc.taboolib.string.language2;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
import me.skymc.taboolib.string.language2.value.*;
|
import me.skymc.taboolib.string.language2.value.*;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@ -13,7 +16,10 @@ import java.util.List;
|
|||||||
*/
|
*/
|
||||||
public class Language2Format implements Language2Line {
|
public class Language2Format implements Language2Line {
|
||||||
|
|
||||||
private Language2Value language2Value;
|
@Getter
|
||||||
|
private Language2Value language2Value = null;
|
||||||
|
|
||||||
|
@Getter
|
||||||
private List<Language2Line> language2Lines = new ArrayList<>();
|
private List<Language2Line> language2Lines = new ArrayList<>();
|
||||||
|
|
||||||
public Language2Format(Player player, Language2Value value) {
|
public Language2Format(Player player, Language2Value value) {
|
||||||
@ -73,7 +79,8 @@ public class Language2Format implements Language2Line {
|
|||||||
parseValue(player, values, type);
|
parseValue(player, values, type);
|
||||||
// 更改类型
|
// 更改类型
|
||||||
type = Language2Type.BOOK;
|
type = Language2Type.BOOK;
|
||||||
} else if (line.contains("[return]")) {
|
}
|
||||||
|
else if (line.contains("[return]")) {
|
||||||
// 递交数据
|
// 递交数据
|
||||||
parseValue(player, values, type);
|
parseValue(player, values, type);
|
||||||
}
|
}
|
||||||
@ -85,14 +92,6 @@ public class Language2Format implements Language2Line {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Language2Value getLanguage2Value() {
|
|
||||||
return language2Value;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<Language2Line> getLanguage2Lines() {
|
|
||||||
return language2Lines;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 识别内容
|
* 识别内容
|
||||||
*
|
*
|
||||||
@ -142,11 +141,15 @@ public class Language2Format implements Language2Line {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void send(Player player) {
|
public void send(Player player) {
|
||||||
language2Lines.forEach(line -> line.send(player));
|
for (Language2Line line : language2Lines) {
|
||||||
|
line.send(player);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void console() {
|
public void console() {
|
||||||
language2Lines.forEach(Language2Line::console);
|
for (Language2Line line : language2Lines) {
|
||||||
|
line.console();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,90 +1,41 @@
|
|||||||
package me.skymc.taboolib.team;
|
package me.skymc.taboolib.team;
|
||||||
|
|
||||||
import com.comphenix.protocol.PacketType;
|
|
||||||
import com.comphenix.protocol.ProtocolLibrary;
|
|
||||||
import com.comphenix.protocol.events.PacketAdapter;
|
|
||||||
import com.comphenix.protocol.events.PacketEvent;
|
|
||||||
import com.comphenix.protocol.wrappers.EnumWrappers;
|
|
||||||
import com.comphenix.protocol.wrappers.PlayerInfoData;
|
|
||||||
import com.comphenix.protocol.wrappers.WrappedGameProfile;
|
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
import com.ilummc.tlib.bungee.api.ChatColor;
|
|
||||||
import me.skymc.taboolib.Main;
|
import me.skymc.taboolib.Main;
|
||||||
import me.skymc.taboolib.events.itag.AsyncPlayerReceiveNameTagEvent;
|
import me.skymc.taboolib.itagapi.TagDataHandler;
|
||||||
import me.skymc.taboolib.events.itag.PlayerReceiveNameTagEvent;
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
|
||||||
import org.bukkit.event.Listener;
|
|
||||||
import org.bukkit.event.player.PlayerJoinEvent;
|
|
||||||
import org.bukkit.event.player.PlayerQuitEvent;
|
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.Set;
|
||||||
import java.util.stream.IntStream;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Author sky
|
* @Author sky
|
||||||
* @Since 2018-05-09 21:03
|
* @Since 2018-05-09 21:03
|
||||||
*/
|
*/
|
||||||
public class TagAPI implements Listener {
|
@Deprecated
|
||||||
|
public class TagAPI {
|
||||||
|
|
||||||
private static final int[] uuidSplit = new int[]{0, 8, 12, 16, 20, 32};
|
/**
|
||||||
|
* 该工具于 2018年5月23日02:31:14 失效
|
||||||
private static boolean loaded = false;
|
* 新工具类: {@link TagDataHandler}
|
||||||
private static HashMap<Integer, Player> entityIdMap = new HashMap<>();
|
*/
|
||||||
private static HashMap<UUID, String> playerData = new HashMap<>();
|
|
||||||
|
|
||||||
TagAPI() {
|
TagAPI() {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void inst() {
|
public static void inst() {
|
||||||
assert !loaded : "TagAPI is already instanced!";
|
|
||||||
loaded = true;
|
|
||||||
|
|
||||||
Bukkit.getServer().getOnlinePlayers().forEach(player -> entityIdMap.put(player.getEntityId(), player));
|
|
||||||
Bukkit.getPluginManager().registerEvents(new TagAPI(), Main.getInst());
|
|
||||||
ProtocolLibrary.getProtocolManager().addPacketListener(new PacketAdapter(Main.getInst(), PacketType.Play.Server.PLAYER_INFO) {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onPacketSending(PacketEvent event) {
|
|
||||||
if (event.getPacket().getPlayerInfoAction().read(0) != EnumWrappers.PlayerInfoAction.ADD_PLAYER) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
List<PlayerInfoData> newPlayerInfo = new ArrayList<>();
|
|
||||||
for (PlayerInfoData playerInfo : event.getPacket().getPlayerInfoDataLists().read(0)) {
|
|
||||||
Player player;
|
|
||||||
if (playerInfo == null || playerInfo.getProfile() == null || (player = Bukkit.getServer().getPlayer(playerInfo.getProfile().getUUID())) == null) {
|
|
||||||
// Unknown Player
|
|
||||||
newPlayerInfo.add(playerInfo);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
newPlayerInfo.add(new PlayerInfoData(getSentName(player.getEntityId(), playerInfo.getProfile(), event.getPlayer()), playerInfo.getPing(), playerInfo.getGameMode(), playerInfo.getDisplayName()));
|
|
||||||
}
|
|
||||||
event.getPacket().getPlayerInfoDataLists().write(0, newPlayerInfo);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String getPlayerDisplayName(Player player) {
|
public static String getPlayerDisplayName(Player player) {
|
||||||
return playerData.getOrDefault(player.getUniqueId(), player.getName());
|
return TagDataHandler.getHandler().getDisplay(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void setPlayerDisplayName(Player player, String name) {
|
public static void setPlayerDisplayName(Player player, String name) {
|
||||||
String nameColored = ChatColor.translateAlternateColorCodes('&', name);
|
TagDataHandler.getHandler().setDisplay(player, name);
|
||||||
player.setDisplayName(nameColored);
|
|
||||||
player.setPlayerListName(nameColored);
|
|
||||||
playerData.put(player.getUniqueId(), nameColored);
|
|
||||||
|
|
||||||
Bukkit.getScheduler().runTask(Main.getInst(), () -> refreshPlayer(player));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void removePlayerDisplayName(Player player) {
|
public static void removePlayerDisplayName(Player player) {
|
||||||
player.setDisplayName(null);
|
TagDataHandler.getHandler().setDisplay(player, player.getName());
|
||||||
player.setPlayerListName(null);
|
|
||||||
playerData.remove(player.getUniqueId());
|
|
||||||
|
|
||||||
Bukkit.getScheduler().runTask(Main.getInst(), () -> refreshPlayer(player));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void refreshPlayer(Player player) {
|
public static void refreshPlayer(Player player) {
|
||||||
@ -112,50 +63,4 @@ public class TagAPI implements Listener {
|
|||||||
|
|
||||||
forWhom.forEach(playerFor -> refreshPlayer(player, playerFor));
|
forWhom.forEach(playerFor -> refreshPlayer(player, playerFor));
|
||||||
}
|
}
|
||||||
|
|
||||||
private static WrappedGameProfile getSentName(int sentEntityId, WrappedGameProfile sent, Player destinationPlayer) {
|
|
||||||
Preconditions.checkState(Bukkit.getServer().isPrimaryThread(), "Can only process events on main thread.");
|
|
||||||
|
|
||||||
Player namedPlayer = entityIdMap.get(sentEntityId);
|
|
||||||
if (namedPlayer == null) {
|
|
||||||
// They probably were dead when we reloaded
|
|
||||||
return sent;
|
|
||||||
}
|
|
||||||
|
|
||||||
PlayerReceiveNameTagEvent oldEvent = new PlayerReceiveNameTagEvent(destinationPlayer, namedPlayer, sent.getName());
|
|
||||||
Bukkit.getServer().getPluginManager().callEvent(oldEvent);
|
|
||||||
|
|
||||||
StringBuilder builtUUID = new StringBuilder();
|
|
||||||
if (!sent.getId().contains("-")) {
|
|
||||||
IntStream.range(0, uuidSplit.length - 1).forEach(i -> builtUUID.append(sent.getId(), uuidSplit[i], uuidSplit[i + 1]).append("-"));
|
|
||||||
} else {
|
|
||||||
builtUUID.append(sent.getId());
|
|
||||||
}
|
|
||||||
|
|
||||||
AsyncPlayerReceiveNameTagEvent newEvent = new AsyncPlayerReceiveNameTagEvent(destinationPlayer, namedPlayer, getPlayerDisplayName(namedPlayer), UUID.fromString(builtUUID.toString()));
|
|
||||||
Bukkit.getServer().getPluginManager().callEvent(newEvent);
|
|
||||||
|
|
||||||
updatePlayerTag(namedPlayer, newEvent);
|
|
||||||
return new WrappedGameProfile(newEvent.getUUID(), newEvent.getTag().substring(0, Math.min(newEvent.getTag().length(), 16)));
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler
|
|
||||||
public void onJoin(PlayerJoinEvent event) {
|
|
||||||
entityIdMap.put(event.getPlayer().getEntityId(), event.getPlayer());
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler
|
|
||||||
public void onQuit(PlayerQuitEvent event) {
|
|
||||||
entityIdMap.remove(event.getPlayer().getEntityId());
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void updatePlayerTag(Player namedPlayer, AsyncPlayerReceiveNameTagEvent newEvent) {
|
|
||||||
TagManager.PlayerData playerData = TagManager.getInst().getPlayerData(namedPlayer);
|
|
||||||
if (playerData.isEmpty()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
TagManager.getInst().unloadData(namedPlayer);
|
|
||||||
playerData.setName(newEvent.getTag());
|
|
||||||
TagManager.getInst().uploadData(namedPlayer);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ package me.skymc.taboolib.team;
|
|||||||
|
|
||||||
import com.ilummc.tlib.util.Strings;
|
import com.ilummc.tlib.util.Strings;
|
||||||
import me.skymc.taboolib.Main;
|
import me.skymc.taboolib.Main;
|
||||||
|
import me.skymc.taboolib.itagapi.TagDataHandler;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
@ -18,16 +19,16 @@ import java.util.UUID;
|
|||||||
* @author sky
|
* @author sky
|
||||||
* @since 2018-03-17 21:43:49
|
* @since 2018-03-17 21:43:49
|
||||||
*/
|
*/
|
||||||
public class TagManager implements Listener {
|
@Deprecated
|
||||||
|
public class TagManager {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 该工具于 2018年5月23日02:31:14 失效
|
||||||
|
* 新工具类: {@link TagDataHandler}
|
||||||
|
*/
|
||||||
|
|
||||||
private static TagManager inst;
|
private static TagManager inst;
|
||||||
|
|
||||||
private HashMap<UUID, PlayerData> playerData = new HashMap<>();
|
|
||||||
|
|
||||||
private TagManager() {
|
|
||||||
Bukkit.getPluginManager().registerEvents(this, Main.getInst());
|
|
||||||
}
|
|
||||||
|
|
||||||
public static TagManager getInst() {
|
public static TagManager getInst() {
|
||||||
synchronized (TagManager.class) {
|
synchronized (TagManager.class) {
|
||||||
if (inst == null) {
|
if (inst == null) {
|
||||||
@ -38,146 +39,37 @@ public class TagManager implements Listener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public HashMap<UUID, PlayerData> getPlayerData() {
|
public HashMap<UUID, PlayerData> getPlayerData() {
|
||||||
return playerData;
|
return new HashMap<>(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 设置玩家前缀
|
|
||||||
*
|
|
||||||
* @param player 名称
|
|
||||||
* @param prefix 前缀
|
|
||||||
*/
|
|
||||||
public void setPrefix(Player player, String prefix) {
|
public void setPrefix(Player player, String prefix) {
|
||||||
getPlayerData(player).setPrefix(prefix);
|
TagDataHandler.getHandler().setPrefix(player, prefix);
|
||||||
uploadData(player);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 设置玩家后缀
|
|
||||||
*
|
|
||||||
* @param player 玩家
|
|
||||||
* @param suffix 后缀
|
|
||||||
*/
|
|
||||||
public void setSuffix(Player player, String suffix) {
|
public void setSuffix(Player player, String suffix) {
|
||||||
getPlayerData(player).setSuffix(suffix);
|
TagDataHandler.getHandler().setSuffix(player, suffix);
|
||||||
uploadData(player);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取玩家前缀
|
|
||||||
*
|
|
||||||
* @param player 玩家
|
|
||||||
* @return String
|
|
||||||
*/
|
|
||||||
public String getPrefix(Player player) {
|
public String getPrefix(Player player) {
|
||||||
return getPlayerData(player).getPrefix();
|
return TagDataHandler.getHandler().getPrefix(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取玩家后缀
|
|
||||||
*
|
|
||||||
* @param player 玩家
|
|
||||||
* @return String
|
|
||||||
*/
|
|
||||||
public String getSuffix(Player player) {
|
public String getSuffix(Player player) {
|
||||||
return getPlayerData(player).getSuffix();
|
return TagDataHandler.getHandler().getSuffix(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取玩家数据
|
|
||||||
*
|
|
||||||
* @param player 玩家
|
|
||||||
* @return {@link PlayerData}
|
|
||||||
*/
|
|
||||||
public PlayerData getPlayerData(Player player) {
|
public PlayerData getPlayerData(Player player) {
|
||||||
return playerData.computeIfAbsent(player.getUniqueId(), k -> new PlayerData(player));
|
return new PlayerData(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 注销称号数据
|
|
||||||
*
|
|
||||||
* @param targetPlayer
|
|
||||||
*/
|
|
||||||
public void unloadData(Player targetPlayer) {
|
public void unloadData(Player targetPlayer) {
|
||||||
PlayerData data = getPlayerData(targetPlayer);
|
TagDataHandler.getHandler().resetVariable(targetPlayer);
|
||||||
for (Player player : Bukkit.getOnlinePlayers()) {
|
|
||||||
Scoreboard scoreboard = getScoreboard(player);
|
|
||||||
Team team = scoreboard.getTeam(data.getName());
|
|
||||||
if (team != null) {
|
|
||||||
team.unregister();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
data.reset();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 将该玩家的数据向服务器所有玩家更新
|
|
||||||
*
|
|
||||||
* @param targetPlayer 玩家
|
|
||||||
*/
|
|
||||||
public void uploadData(Player targetPlayer) {
|
public void uploadData(Player targetPlayer) {
|
||||||
PlayerData data = getPlayerData(targetPlayer);
|
|
||||||
String prefix = data.getPrefix().length() > 16 ? data.getPrefix().substring(0, 16) : data.getPrefix();
|
|
||||||
String suffix = data.getSuffix().length() > 16 ? data.getSuffix().substring(0, 16) : data.getSuffix();
|
|
||||||
// 如果没有称号数据
|
|
||||||
if (prefix.isEmpty() && suffix.isEmpty()) {
|
|
||||||
unloadData(targetPlayer);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (Player player : Bukkit.getOnlinePlayers()) {
|
|
||||||
Scoreboard scoreboard = getScoreboard(player);
|
|
||||||
Team team = getTeam(scoreboard, data);
|
|
||||||
team.setPrefix(prefix);
|
|
||||||
team.setSuffix(suffix);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 下载服务器内的称号数据到该玩家
|
|
||||||
*
|
|
||||||
* @param targetPlayer 玩家
|
|
||||||
*/
|
|
||||||
public void downloadData(Player targetPlayer) {
|
public void downloadData(Player targetPlayer) {
|
||||||
Scoreboard scoreboard = getScoreboard(targetPlayer);
|
|
||||||
for (Player player : Bukkit.getOnlinePlayers()) {
|
|
||||||
PlayerData data = getPlayerData(player);
|
|
||||||
String prefix = data.getPrefix().length() > 16 ? data.getPrefix().substring(0, 16) : data.getPrefix();
|
|
||||||
String suffix = data.getSuffix().length() > 16 ? data.getSuffix().substring(0, 16) : data.getSuffix();
|
|
||||||
// 如果没有称号数据
|
|
||||||
if (prefix.isEmpty() && suffix.isEmpty()) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
Team team = getTeam(scoreboard, data);
|
|
||||||
team.setPrefix(prefix);
|
|
||||||
team.setSuffix(suffix);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler
|
|
||||||
public void onJoin(PlayerJoinEvent e) {
|
|
||||||
downloadData(e.getPlayer());
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler
|
|
||||||
public void onQuit(PlayerQuitEvent e) {
|
|
||||||
unloadData(e.getPlayer());
|
|
||||||
}
|
|
||||||
|
|
||||||
private Scoreboard getScoreboard(Player player) {
|
|
||||||
Scoreboard scoreboard = player.getScoreboard();
|
|
||||||
if (scoreboard == null) {
|
|
||||||
player.setScoreboard(Bukkit.getScoreboardManager().getNewScoreboard());
|
|
||||||
}
|
|
||||||
return scoreboard;
|
|
||||||
}
|
|
||||||
|
|
||||||
private Team getTeam(Scoreboard scoreboard, PlayerData data) {
|
|
||||||
Team team = scoreboard.getTeam(String.valueOf(data.getPrefix()));
|
|
||||||
if (team == null) {
|
|
||||||
team = scoreboard.registerNewTeam(String.valueOf(data.getPrefix()));
|
|
||||||
team.addEntry(data.getName());
|
|
||||||
}
|
|
||||||
return team;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static class PlayerData {
|
static class PlayerData {
|
||||||
|
@ -1,131 +0,0 @@
|
|||||||
package me.skymc.taboolib.team;
|
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.entity.Player;
|
|
||||||
import org.bukkit.scoreboard.Scoreboard;
|
|
||||||
import org.bukkit.scoreboard.Team;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author sky
|
|
||||||
* @since 2018-03-17 21:36:52
|
|
||||||
*/
|
|
||||||
public class TagUtils {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 设置玩家前后缀
|
|
||||||
*
|
|
||||||
* @param p 玩家
|
|
||||||
* @param prefix 前缀
|
|
||||||
* @param suffix 后缀
|
|
||||||
*/
|
|
||||||
public static void setTag(Player p, String prefix, String suffix) {
|
|
||||||
// 判断长度
|
|
||||||
if (prefix.length() > 16) {
|
|
||||||
prefix = prefix.substring(0, 16);
|
|
||||||
}
|
|
||||||
if (suffix.length() > 16) {
|
|
||||||
suffix = suffix.substring(0, 16);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 获取计分板
|
|
||||||
Scoreboard board = Bukkit.getScoreboardManager().getMainScoreboard();
|
|
||||||
Team t = board.getTeam(p.getName());
|
|
||||||
if (t == null) {
|
|
||||||
t = board.registerNewTeam(p.getName());
|
|
||||||
}
|
|
||||||
|
|
||||||
// 更新称号
|
|
||||||
t.setPrefix(prefix);
|
|
||||||
t.setSuffix(suffix);
|
|
||||||
t.addEntry(p.getName());
|
|
||||||
|
|
||||||
// 更新玩家
|
|
||||||
for (Player o : Bukkit.getOnlinePlayers()) {
|
|
||||||
if (!board.equals(o.getScoreboard())) {
|
|
||||||
o.setScoreboard(board);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 注销玩家前后缀
|
|
||||||
*
|
|
||||||
* @param p 玩家
|
|
||||||
*/
|
|
||||||
public static void unregisterTag(Player p) {
|
|
||||||
Team team = Bukkit.getScoreboardManager().getMainScoreboard().getTeam(p.getName());
|
|
||||||
if (team != null) {
|
|
||||||
team.unregister();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 注销所有在线玩家前后缀
|
|
||||||
*/
|
|
||||||
public static void unregisterAll() {
|
|
||||||
for (Player o : Bukkit.getOnlinePlayers()) {
|
|
||||||
unregisterTag(o);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 删除所有前后缀
|
|
||||||
*/
|
|
||||||
public static void delete() {
|
|
||||||
for (Team t : Bukkit.getScoreboardManager().getMainScoreboard().getTeams()) {
|
|
||||||
t.unregister();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 设置全服玩家前后缀
|
|
||||||
*
|
|
||||||
* @param prefix 前缀
|
|
||||||
* @param suffix 后缀
|
|
||||||
*/
|
|
||||||
public static void registerAll(String prefix, String suffix) {
|
|
||||||
for (Player o : Bukkit.getOnlinePlayers()) {
|
|
||||||
setTag(o, prefix, suffix);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 刷新计分板数据
|
|
||||||
*/
|
|
||||||
public static void refresh() {
|
|
||||||
Scoreboard board = Bukkit.getScoreboardManager().getMainScoreboard();
|
|
||||||
for (Player o : Bukkit.getOnlinePlayers()) {
|
|
||||||
o.setScoreboard(board);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取玩家前缀
|
|
||||||
*
|
|
||||||
* @param p 玩家
|
|
||||||
* @return String
|
|
||||||
*/
|
|
||||||
public static String getPrefix(Player p) {
|
|
||||||
Scoreboard board = Bukkit.getScoreboardManager().getMainScoreboard();
|
|
||||||
Team t = board.getTeam(p.getName());
|
|
||||||
if (t != null) {
|
|
||||||
return t.getPrefix();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取玩玩家后缀
|
|
||||||
*
|
|
||||||
* @param p 玩家
|
|
||||||
* @return String
|
|
||||||
*/
|
|
||||||
public static String getSuffix(Player p) {
|
|
||||||
Scoreboard board = Bukkit.getScoreboardManager().getMainScoreboard();
|
|
||||||
Team t = board.getTeam(p.getName());
|
|
||||||
if (t != null) {
|
|
||||||
return t.getSuffix();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
@ -164,6 +164,9 @@ COMMANDS:
|
|||||||
- '&8[&3&lTabooLib&8] &7你可能想要:'
|
- '&8[&3&lTabooLib&8] &7你可能想要:'
|
||||||
- '&8[&3&lTabooLib&8] &7{1}'
|
- '&8[&3&lTabooLib&8] &7{1}'
|
||||||
COMMAND-REGISTER: '&7自动为插件 &f{0} &7的命令 &f{1} &7注册 &f{2} &7条子命令'
|
COMMAND-REGISTER: '&7自动为插件 &f{0} &7的命令 &f{1} &7注册 &f{2} &7条子命令'
|
||||||
|
COMMAND-HELP: ' §f/{0} {1} {2} §6- §e{3}'
|
||||||
|
COMMAND-ARGUMENT: '§7<§8{0}§7>'
|
||||||
|
COMMAND-ARGUMENT-REQUIRE: '§7[§8{0}§7]'
|
||||||
PARAMETER:
|
PARAMETER:
|
||||||
UNKNOWN: '&8[&3&lTabooLib&8] &4指令错误'
|
UNKNOWN: '&8[&3&lTabooLib&8] &4指令错误'
|
||||||
INSUFFICIENT: '&8[&3&lTabooLib&8] &4参数不足'
|
INSUFFICIENT: '&8[&3&lTabooLib&8] &4参数不足'
|
||||||
|
Loading…
Reference in New Issue
Block a user