Made some changes

- Made command registration for other plugins more flexible
- Using logger instead of sysout
- Started moving plugin updater to the core
This commit is contained in:
Norbi Peti 2016-08-14 14:41:54 +02:00
parent 8e091beb33
commit 6d883ddbef
9 changed files with 65 additions and 66 deletions

View file

@ -1,6 +1,6 @@
package buttondevteam.thebuttonmcchat;
import java.util.ArrayList;
import java.io.Serializable;
import java.util.HashMap;
import java.util.List;
import java.util.UUID;
@ -9,7 +9,8 @@ import org.bukkit.Bukkit;
import org.bukkit.Location;
import org.bukkit.entity.Player;
public class ChatPlayer {
public class ChatPlayer implements Serializable {
private static final long serialVersionUID = 208589136914849018L;
public String PlayerName;
public String UserName;
public List<String> UserNames;

View file

@ -106,7 +106,8 @@ public class ChatProcessing {
.add(new ChatFormatter(Pattern.compile(sb.toString()), ChatFormatter.Color.Aqua, (String match) -> {
Player p = Bukkit.getPlayer(match);
if (p == null) {
System.out.println("Error: Can't find player " + match + " but it was reported as online.");
PluginMain.Instance.getLogger()
.warning("Error: Can't find player " + match + " but it was reported as online.");
return false;
}
ChatPlayer mpp = ChatPlayer.GetFromPlayer(p);
@ -139,7 +140,7 @@ public class ChatProcessing {
return false; // TODO
Player p = Bukkit.getPlayer(PlayerListener.nicknames.get(n));
if (p == null) {
System.out.println(
PluginMain.Instance.getLogger().warning(
"Error: Can't find player " + match + " but it was reported as online.");
return false;
}

View file

@ -243,8 +243,9 @@ public class PlayerListener implements Listener {
ChatPlayer player = new ChatPlayer();
player.UUID = p.UUID;
player.SetFlair(ChatPlayer.FlairTimeNone);
player.FlairState = FlairStates.NoComment; //TODO: NullPointerException
player.UserNames = new ArrayList<>(); //TODO: Move some code here from join?
player.FlairState = FlairStates.NoComment; // TODO: NullPointerException
player.UserNames = new ArrayList<>(); // TODO: Move some code here from
// join?
ChatPlayer.OnlinePlayers.put(p.UUID, player);
}
@ -603,7 +604,7 @@ public class PlayerListener implements Listener {
@SuppressWarnings("deprecation")
public void onVotifierEvent(VotifierEvent event) {
Vote vote = event.getVote();
System.out.println("Vote: " + vote);
PluginMain.Instance.getLogger().info("Vote: " + vote);
org.bukkit.OfflinePlayer op = Bukkit.getOfflinePlayer(vote.getUsername());
Player p = Bukkit.getPlayer(vote.getUsername());
if (op != null) {
@ -676,7 +677,8 @@ public class PlayerListener implements Listener {
if (block.getType() == Material.ENDER_CHEST) {
e.setCancelled(true);
e.getPlayer().sendMessage("§You are not allowed to use enderchests here.");
System.out.println(e.getPlayer().getName() + " tried to use an enderchest in twohundred.");
PluginMain.Instance.getLogger()
.warning(e.getPlayer().getName() + " tried to use an enderchest in twohundred.");
}
}
}

View file

@ -55,7 +55,7 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
@Override
public void onEnable() {
try {
System.out.println("Extracting necessary libraries...");
PluginMain.Instance.getLogger().info("Extracting necessary libraries...");
final File[] libs = new File[] { new File(getDataFolder(), "htmlcleaner-2.16.jar"),
new File(getDataFolder(), "reflections-0.9.10.jar"),
new File(getDataFolder(), "javassist-3.19.0-GA.jar") };
@ -77,7 +77,7 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
}
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
CommandCaller.RegisterCommands(this);
CommandCaller.RegisterChatCommands(this);
Instance = this;
Console = this.getServer().getConsoleSender();
LoadFiles(false);
@ -108,7 +108,7 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
Runnable r = new Runnable() {
public void run() {
ThreadMethod();
FlairGetterThreadMethod();
}
};
Thread t = new Thread(r);
@ -131,7 +131,7 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
stop = true;
}
private void ThreadMethod() {
private void FlairGetterThreadMethod() {
while (!stop) {
try {
String body = DownloadString(FlairThreadURL + ".json?limit=1000");
@ -141,11 +141,11 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
String author = item.getJSONObject("data").getString("author");
String ign = item.getJSONObject("data").getString("body");
int start = ign.indexOf("IGN:") + "IGN:".length();
if (start == -1 + "IGN:".length()) // +length: 2015.08.10.
continue; // 2015.08.09.
if (start == -1 + "IGN:".length())
continue;
int end = ign.indexOf(' ', start);
if (end == -1 || end == start)
end = ign.indexOf('\n', start); // 2015.07.15.
end = ign.indexOf('\n', start);
if (end == -1 || end == start)
ign = ign.substring(start);
else
@ -174,8 +174,7 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
Thread.currentThread().interrupt();
}
} catch (Exception e) {
// System.out.println("Error!\n" + e);
LastException = e; // 2015.08.09.
LastException = e;
}
}
}
@ -196,7 +195,7 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
SetFlair(mp, flair, flairclass, mp.UserName);
}
public static Exception LastException; // 2015.08.09.
public static Exception LastException;
public String DownloadString(String urlstr) throws MalformedURLException, IOException {
URL url = new URL(urlstr);
@ -295,11 +294,11 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
public static void LoadFiles(boolean reload) {
if (reload) {
System.out.println("TBMC chat plugin cleanup for reloading...");
PluginMain.Instance.getLogger().info("Cleanup for reloading...");
ChatPlayer.OnlinePlayers.clear();
AnnounceMessages.clear();
}
System.out.println("Loading files for TBMC chat plugin...");
PluginMain.Instance.getLogger().info("Loading files...");
try {
File file = new File("thebuttonmc.yml"); // TODO
if (file.exists()) {
@ -312,18 +311,18 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
AnnounceMessages.addAll(yc.getStringList("announcements"));
PlayerListener.AlphaDeaths = yc.getInt("alphadeaths");
}
System.out.println("TBMC plugin loaded files!");
PluginMain.Instance.getLogger().info("Loaded files!");
} catch (IOException e) {
System.out.println("Error!\n" + e);
PluginMain.Instance.getLogger().warning("Error!\n" + e);
LastException = e;
} catch (InvalidConfigurationException e) {
System.out.println("Error!\n" + e);
PluginMain.Instance.getLogger().warning("Error!\n" + e);
LastException = e;
}
}
public static void SaveFiles() {
System.out.println("Saving files for The Button Minecraft plugin...");
PluginMain.Instance.getLogger().info("Saving files...");
try {
File file = new File("thebuttonmc.yml");
YamlConfiguration yc = new YamlConfiguration();
@ -333,9 +332,9 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
yc.set("announcements", AnnounceMessages);
yc.set("alphadeaths", PlayerListener.AlphaDeaths);
yc.save(file);
System.out.println("The Button Minecraft plugin saved files!");
PluginMain.Instance.getLogger().info("Saved files!");
} catch (IOException e) {
System.out.println("Error!\n" + e);
PluginMain.Instance.getLogger().warning("Error!\n" + e);
LastException = e;
}
}

View file

@ -10,20 +10,24 @@ public class TBMCChatAPI {
/**
* <p>
* This method adds a command, adding it to help for example.
* This method adds a plugin's commands to help and sets their executor.
* </p>
* <p>
* The command must be registered in the caller plugin's plugin.yml.
* The <u>command must be registered</u> in the caller plugin's plugin.yml.
* Otherwise the plugin will output a messsage to console.
* </p>
*
* @param plugin
* The caller plugin
* @param cmd
* The command to add
* @param acmdclass
* A command's class to get the package name for commands. The
* provided class's package and subpackages are scanned for
* commands.
*/
public void AddCommand(JavaPlugin plugin, TBMCCommandBase cmd) {
CommandCaller.AddCommand(plugin, cmd);
public void AddCommands(JavaPlugin plugin, Class<? extends TBMCCommandBase> acmdclass) {
CommandCaller.AddCommands(plugin, acmdclass); // TODO: Make it scan for
// all "buttondevteam"
// packages
}
/**

View file

@ -33,19 +33,19 @@ public class CommandCaller implements CommandExecutor {
private static CommandCaller instance;
public static void RegisterCommands(PluginMain plugin) {
if (instance != null) {
new Exception("Only one instance of CommandCaller is allowed").printStackTrace();
return;
public static void RegisterChatCommands(PluginMain plugin) {
AddCommands(plugin, TBMCCommandBase.class);
}
System.out.println("Registering commands...");
// TODO: Move plugin updater to the core
public static void AddCommands(JavaPlugin plugin, Class<? extends TBMCCommandBase> acmdclass) {
plugin.getLogger().info("Registering commands for " + plugin.getName());
if (instance == null)
instance = new CommandCaller();
Reflections rf = new Reflections(
new ConfigurationBuilder().setUrls(ClasspathHelper.forClassLoader(plugin.getClass().getClassLoader()))
.addClassLoader(plugin.getClass().getClassLoader()).addScanners(new SubTypesScanner())
.filterInputsBy((String pkg) -> pkg.contains("buttondevteam.thebuttonmcchat.commands")));
.filterInputsBy((String pkg) -> pkg.contains(acmdclass.getPackage().getName())));
Set<Class<? extends TBMCCommandBase>> cmds = rf.getSubTypesOf(TBMCCommandBase.class);
for (Class<? extends TBMCCommandBase> cmd : cmds) {
try {
@ -69,20 +69,6 @@ public class CommandCaller implements CommandExecutor {
}
}
public static void AddCommand(JavaPlugin plugin, TBMCCommandBase cmd) {
if (instance == null)
instance = new CommandCaller();
commands.put(cmd.GetCommandPath(), cmd);
if (!cmd.GetCommandPath().contains("/")) // Top-level command
{
PluginCommand pc = plugin.getCommand(cmd.GetCommandPath());
if (pc == null)
new Exception("Can't find top-level command: " + cmd.GetCommandPath()).printStackTrace();
else
pc.setExecutor(instance);
}
}
@Override
public boolean onCommand(CommandSender sender, Command command, String alias, String[] args) {
String path = command.getName();

View file

@ -31,7 +31,7 @@ public class ConfirmCommand extends AdminCommandBase {
sender.sendMessage("§6-- Reloading done!§r");
ReloadCommand.Reloader = null;
} catch (Exception e) {
System.out.println("Error!\n" + e);
PluginMain.Instance.getLogger().warning("Error!\n" + e);
if (sender != PluginMain.Console)
sender.sendMessage("§cAn error occured. See console for details.§r");
PluginMain.LastException = e;

View file

@ -2,6 +2,8 @@ package buttondevteam.thebuttonmcchat.commands.ucmds.admin;
import org.bukkit.command.CommandSender;
import buttondevteam.thebuttonmcchat.PluginMain;
public class DebugCommand extends AdminCommandBase {
private static boolean DebugMode = false;
@ -25,6 +27,6 @@ public class DebugCommand extends AdminCommandBase {
public static void SendDebugMessage(String message) {
if (DebugMode)
System.out.println(message);
PluginMain.Instance.getLogger().info(message);
}
}

View file

@ -15,26 +15,30 @@ public class UpdatePlugin extends AdminCommandBase {
@Override
public String[] GetHelpText(String alias) {
return new String[] { "§6---- Update plugin ----",
"This command downloads the latest version of the plugin from GitHub" };
"This command downloads the latest version of a TBMC plugin from GitHub",
"To update a plugin: /" + alias + " <plugin>", "To list the plugin names: /" + alias };
}
@Override
public boolean OnCommand(CommandSender sender, String alias,
String[] args) {
sender.sendMessage("Updating Auto-Flair plugin...");
System.out.println("Forced updating of Auto-Flair plugin.");
public boolean OnCommand(CommandSender sender, String alias, String[] args) {
if (args.length == 0)
{
sender.sendMessage("§6---- Plugin names ----");
for(Plugin plugin : TBMC)
sender.sendMessage("");
}
sender.sendMessage("Updating plugin...");
PluginMain.Instance.getLogger().info("Forced updating of the plugin.");
URL url;
try {
url = new URL(
"https://github.com/NorbiPeti/thebuttonmcchat/raw/master/TheButtonMCChat.jar");
FileUtils.copyURLToFile(url, new File(
"plugins/TheButtonMCChat.jar"));
url = new URL("https://github.com/NorbiPeti/thebuttonmcchat/raw/master/TheButtonMCChat.jar");
FileUtils.copyURLToFile(url, new File("plugins/TheButtonMCChat.jar"));
sender.sendMessage("Updating done!");
} catch (MalformedURLException e) {
System.out.println("Error!\n" + e);
PluginMain.Instance.getLogger().warning("Error!\n" + e);
PluginMain.LastException = e;
} catch (IOException e) {
System.out.println("Error!\n" + e);
PluginMain.Instance.getLogger().warning("Error!\n" + e);
PluginMain.LastException = e;
}
return true;