Change registration order in enable / disable.

This commit is contained in:
asofold 2012-09-04 08:52:03 +02:00
parent c89e6c6957
commit b262753f4f

View File

@ -73,6 +73,7 @@ public class NoCheatPlus extends JavaPlugin implements Listener {
* @param listener
*/
private void addListener(final Listener listener){
Bukkit.getPluginManager().registerEvents(listener, this);
listeners.add(listener);
if (listener instanceof INotifyReload){
notifyReload.add((INotifyReload) listener);
@ -93,6 +94,9 @@ public class NoCheatPlus extends JavaPlugin implements Listener {
*/
final PluginDescriptionFile pdfFile = getDescription();
// Just to be sure nothing gets left out.
getServer().getScheduler().cancelTasks(this);
// Stop the lag measuring task.
LagMeasureTask.cancel();
@ -105,9 +109,6 @@ public class NoCheatPlus extends JavaPlugin implements Listener {
// Cleanup the configuration manager.
ConfigManager.cleanup();
// Just to be sure nothing gets left out.
getServer().getScheduler().cancelTasks(this);
// Tell the server administrator the we finished unloading NoCheatPlus.
System.out.println("[NoCheatPlus] Version " + pdfFile.getVersion() + " is disabled.");
}
@ -124,11 +125,12 @@ public class NoCheatPlus extends JavaPlugin implements Listener {
* | |___| | | | (_| | |_) | | __/
* |_____|_| |_|\__,_|_.__/|_|\___|
*/
// Read the configuration files.
ConfigManager.init(this);
// List the events listeners.
listeners.clear();
// List the events listeners and register.
Bukkit.getPluginManager().registerEvents(this, this);
for (final Listener listener : new Listener[]{
new BlockBreakListener(),
new BlockInteractListener(),
@ -142,17 +144,12 @@ public class NoCheatPlus extends JavaPlugin implements Listener {
addListener(listener);
}
// Set up a task to monitor server lag.
LagMeasureTask.start(this);
// Register all listeners.
for (final Listener listener : listeners)
Bukkit.getPluginManager().registerEvents(listener, this);
Bukkit.getPluginManager().registerEvents(this, this);
// Register the commands handler.
getCommand("nocheatplus").setExecutor(new CommandHandler(this, notifyReload));
// Set up a task to monitor server lag.
LagMeasureTask.start(this);
ConfigFile config = ConfigManager.getConfigFile();
// Setup the graphs, plotters and start Metrics.