From 8808036762eaef6f12f0492a7fb86ee0e5b879b2 Mon Sep 17 00:00:00 2001 From: 502647092 Date: Wed, 18 May 2016 21:59:33 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E6=B7=BB=E5=8A=A0find=E6=8C=87?= =?UTF-8?q?=E4=BB=A4=20=E7=94=A8=E4=BA=8E=E6=9F=A5=E6=89=BE=E6=9F=90?= =?UTF-8?q?=E4=B8=AA=E7=B1=BB=E6=89=80=E5=AF=B9=E5=BA=94=E7=9A=84=E6=8F=92?= =?UTF-8?q?=E4=BB=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/pw/yumc/Yum/commands/YumCommand.java | 35 ++++++++++++++----- 1 file changed, 26 insertions(+), 9 deletions(-) diff --git a/src/main/java/pw/yumc/Yum/commands/YumCommand.java b/src/main/java/pw/yumc/Yum/commands/YumCommand.java index b030175..a1fa154 100644 --- a/src/main/java/pw/yumc/Yum/commands/YumCommand.java +++ b/src/main/java/pw/yumc/Yum/commands/YumCommand.java @@ -1,5 +1,6 @@ package pw.yumc.Yum.commands; +import java.lang.reflect.Field; import java.util.ArrayList; import java.util.Arrays; import java.util.List; @@ -15,13 +16,14 @@ import org.bukkit.event.player.PlayerJoinEvent; import org.bukkit.permissions.Permission; import org.bukkit.plugin.Plugin; import org.bukkit.plugin.PluginDescriptionFile; +import org.bukkit.plugin.java.JavaPlugin; import cn.citycraft.PluginHelper.commands.HandlerCommand; import cn.citycraft.PluginHelper.commands.HandlerCommands; import cn.citycraft.PluginHelper.commands.HandlerTabComplete; import cn.citycraft.PluginHelper.commands.InvokeCommandEvent; import cn.citycraft.PluginHelper.commands.InvokeSubCommand; -import cn.citycraft.PluginHelper.utils.StringUtil; +import cn.citycraft.PluginHelper.utils.StrKit; import pw.yumc.Yum.Yum; import pw.yumc.Yum.api.YumAPI; import pw.yumc.Yum.managers.PluginsManager; @@ -66,6 +68,21 @@ public class YumCommand implements HandlerCommands, Listener { } } + @HandlerCommand(name = "find", aliases = { "f" }, minimumArguments = 1, possibleArguments = "<插件类名>", description = "通过类名查找插件") + public void find(final InvokeCommandEvent e) { + final String classname = e.getArgs()[0]; + final CommandSender sender = e.getSender(); + try { + final Class clazz = Class.forName(classname); + final Field field = clazz.getClass().getDeclaredField("plugin"); + field.setAccessible(true); + final Plugin plugin = (JavaPlugin) field.get(clazz); + Bukkit.dispatchCommand(sender, "yum info " + plugin.getName()); + } catch (final ClassNotFoundException | NoSuchFieldException | SecurityException | IllegalArgumentException | IllegalAccessException e2) { + sender.sendMessage("§4错误: 无法找到类 " + classname + " 所对应的插件信息!"); + } + } + @HandlerCommand(name = "fulldelete", aliases = { "fdel" }, minimumArguments = 1, description = "删除插件以及数据文件夹", possibleArguments = "<插件名称>") public void fulldelete(final InvokeCommandEvent e) { final String pluginname = e.getArgs()[0]; @@ -95,9 +112,9 @@ public class YumCommand implements HandlerCommands, Listener { sender.sendMessage("§6插件作者: §3" + StringUtils.join(desc.getAuthors(), " ")); sender.sendMessage("§6插件描述: §3" + (desc.getDescription() == null ? "无" : desc.getDescription())); sender.sendMessage("§6插件依赖: §3" + (desc.getDepend().isEmpty() ? "无" : "")); - StringUtil.sendStringArray(sender, desc.getDepend(), "§6 - §a"); + StrKit.sendStringArray(sender, desc.getDepend(), "§6 - §a"); sender.sendMessage("§6插件软依赖: §3" + (desc.getSoftDepend().isEmpty() ? "无" : "")); - StringUtil.sendStringArray(sender, desc.getSoftDepend(), "§6 - §a"); + StrKit.sendStringArray(sender, desc.getSoftDepend(), "§6 - §a"); final Map> clist = desc.getCommands(); if (clist != null) { sender.sendMessage("§6插件注册命令: §3" + (clist.isEmpty() ? "无" : "")); @@ -156,17 +173,17 @@ public class YumCommand implements HandlerCommands, Listener { public List listtab(final InvokeCommandEvent e) { final String[] args = e.getArgs(); if (!args[0].equalsIgnoreCase("install") && !args[0].equalsIgnoreCase("repo")) { - return StringUtil.copyPartialMatches(args[1], plugman.getPluginNames(false), new ArrayList()); + return StrKit.copyPartialMatches(args[1], plugman.getPluginNames(false), new ArrayList()); } if (args[0].equalsIgnoreCase("install")) { - return StringUtil.copyPartialMatches(args[1], repo.getAllPluginName(), new ArrayList()); + return StrKit.copyPartialMatches(args[1], repo.getAllPluginName(), new ArrayList()); } if (args[0].equalsIgnoreCase("repo")) { if (args.length == 2) { - return StringUtil.copyPartialMatches(args[1], Arrays.asList(new String[] { "add", "all", "list", "delall", "clean", "update", "del" }), new ArrayList()); + return StrKit.copyPartialMatches(args[1], Arrays.asList(new String[] { "add", "all", "list", "delall", "clean", "update", "del" }), new ArrayList()); } if (args.length == 3 && (args[1] == "add" || args[1] == "del")) { - return StringUtil.copyPartialMatches(args[2], repo.getRepos().keySet(), new ArrayList()); + return StrKit.copyPartialMatches(args[2], repo.getRepos().keySet(), new ArrayList()); } } return null; @@ -247,11 +264,11 @@ public class YumCommand implements HandlerCommands, Listener { break; case "list": sender.sendMessage("§6仓库: §b缓存的插件信息如下 "); - StringUtil.sendStringArray(sender, repo.getAllPluginsInfo()); + StrKit.sendStringArray(sender, repo.getAllPluginsInfo()); break; case "all": sender.sendMessage("§6仓库: §b缓存的仓库信息如下 "); - StringUtil.sendStringArray(sender, repo.getRepoCache().getAllRepoInfo()); + StrKit.sendStringArray(sender, repo.getRepoCache().getAllRepoInfo()); break; case "clean": repo.clean();