Be able to run without onLoad being called.

This commit is contained in:
asofold 2015-01-17 05:20:18 +01:00
parent 6de0ea94bb
commit d52dd4b158

View File

@ -740,17 +740,31 @@ public class NoCheatPlus extends JavaPlugin implements NoCheatPlusAPI {
*/ */
@Override @Override
public void onLoad() { public void onLoad() {
Bukkit.getLogger().info("[NoCheatPlus] Setting up static API, config, logging."); Bukkit.getLogger().info("[NoCheatPlus] onLoad: Early set up of static API, configuration, logging.");
setupBasics();
}
/**
* Lazy initialization of basics (static API, configuration, logging).
*/
private void setupBasics() {
if (NCPAPIProvider.getNoCheatPlusAPI() == null) {
NCPAPIProvider.setNoCheatPlusAPI(this); NCPAPIProvider.setNoCheatPlusAPI(this);
}
if (ServerVersion.getMinecraftVersion() == ServerVersion.UNKNOWN_VERSION) {
BukkitVersion.init(); BukkitVersion.init();
// Read the configuration files. }
ConfigManager.init(this); // TODO: Only load the bootstrap config (not all). if (!ConfigManager.isInitialized()) {
ConfigManager.init(this);
}
if (logManager == null || logManager.getStreamID(Streams.STATUS.name) != Streams.STATUS) {
logManager = new BukkitLogManager(this); logManager = new BukkitLogManager(this);
StaticLog.setStreamID(Streams.INIT); StaticLog.setStreamID(Streams.INIT);
StaticLog.setUseLogManager(true); StaticLog.setUseLogManager(true);
logManager.info(Streams.INIT, "[NoCheatPlus] Logging system initialized."); logManager.info(Streams.INIT, "[NoCheatPlus] Logging system initialized.");
logManager.info(Streams.INIT, "[NoCheatPlus] Detected Minecraft version: " + ServerVersion.getMinecraftVersion()); logManager.info(Streams.INIT, "[NoCheatPlus] Detected Minecraft version: " + ServerVersion.getMinecraftVersion());
} }
}
/* (non-Javadoc) /* (non-Javadoc)
* @see org.bukkit.plugin.java.JavaPlugin#onEnable() * @see org.bukkit.plugin.java.JavaPlugin#onEnable()
@ -764,23 +778,20 @@ public class NoCheatPlus extends JavaPlugin implements NoCheatPlusAPI {
TickTask.cancel(); TickTask.cancel();
TickTask.reset(); TickTask.reset();
// Allow entries to TickTask (just in case). // Allow entries to TickTask.
TickTask.setLocked(false); TickTask.setLocked(false);
// Initialize configuration, if needed. // Re-check basic setup (if onLoad gets skipped by some custom thing).
if (!ConfigManager.isInitialized()) { setupBasics();
// Read the configuration files (should only happen on reloading).
ConfigManager.init(this); // Start logger task(s).
} logManager.startTasks();
final ConfigFile config = ConfigManager.getConfigFile(); final ConfigFile config = ConfigManager.getConfigFile();
useSubscriptions = config.getBoolean(ConfPaths.LOGGING_BACKEND_INGAMECHAT_SUBSCRIPTIONS); useSubscriptions = config.getBoolean(ConfPaths.LOGGING_BACKEND_INGAMECHAT_SUBSCRIPTIONS);
// Start logger task(s). // Listener manager.
logManager.startTasks();
manageListeners = config.getBoolean(ConfPaths.COMPATIBILITY_MANAGELISTENERS); manageListeners = config.getBoolean(ConfPaths.COMPATIBILITY_MANAGELISTENERS);
if (manageListeners) { if (manageListeners) {
listenerManager.setRegisterDirectly(true); listenerManager.setRegisterDirectly(true);