13
0
geforkt von Mirrors/Paper

Shift plugin initialization; Addresses BUKKIT-1788

By: Wesley Wolfe <weswolf@aol.com>
Dieser Commit ist enthalten in:
Bukkit/Spigot 2012-06-11 01:45:41 -05:00
Ursprung e88d605bc3
Commit 5d9e74a637
3 geänderte Dateien mit 37 neuen und 4 gelöschten Zeilen

Datei anzeigen

@ -49,7 +49,12 @@ public abstract class JavaPlugin extends PluginBase {
private File configFile = null; private File configFile = null;
private PluginLogger logger = null; private PluginLogger logger = null;
public JavaPlugin() {} public JavaPlugin() {
ClassLoader classLoader = this.getClass().getClassLoader();
if (classLoader instanceof PluginClassLoader) {
((PluginClassLoader) classLoader).initialize(this);
}
}
/** /**
* Returns the folder that the plugin data's files are located in. The * Returns the folder that the plugin data's files are located in. The

Datei anzeigen

@ -134,7 +134,7 @@ public class JavaPluginLoader implements PluginLoader {
loader = loaders.get(description.getClassLoaderOf()); loader = loaders.get(description.getClassLoaderOf());
loader.addURL(urls[0]); loader.addURL(urls[0]);
} else { } else {
loader = new PluginClassLoader(this, urls, getClass().getClassLoader()); loader = new PluginClassLoader(this, urls, getClass().getClassLoader(), server, description, dataFolder, file);
} }
Class<?> jarClass = Class.forName(description.getMain(), true, loader); Class<?> jarClass = Class.forName(description.getMain(), true, loader);
@ -143,8 +143,6 @@ public class JavaPluginLoader implements PluginLoader {
Constructor<? extends JavaPlugin> constructor = plugin.getConstructor(); Constructor<? extends JavaPlugin> constructor = plugin.getConstructor();
result = constructor.newInstance(); result = constructor.newInstance();
result.initialize(this, server, description, dataFolder, file, loader);
} catch (InvocationTargetException ex) { } catch (InvocationTargetException ex) {
throw new InvalidPluginException(ex.getCause()); throw new InvalidPluginException(ex.getCause());
} catch (Throwable ex) { } catch (Throwable ex) {

Datei anzeigen

@ -1,22 +1,43 @@
package org.bukkit.plugin.java; package org.bukkit.plugin.java;
import java.io.File;
import java.net.URL; import java.net.URL;
import java.net.URLClassLoader; import java.net.URLClassLoader;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import org.apache.commons.lang.Validate;
import org.bukkit.Server;
import org.bukkit.plugin.PluginDescriptionFile;
/** /**
* A ClassLoader for plugins, to allow shared classes across multiple plugins * A ClassLoader for plugins, to allow shared classes across multiple plugins
*/ */
public class PluginClassLoader extends URLClassLoader { public class PluginClassLoader extends URLClassLoader {
private final JavaPluginLoader loader; private final JavaPluginLoader loader;
private final Map<String, Class<?>> classes = new HashMap<String, Class<?>>(); private final Map<String, Class<?>> classes = new HashMap<String, Class<?>>();
private final PluginDescriptionFile description;
private final Server server;
private final File dataFolder;
private final File file;
/**
* Changed in favor of class loader that initializes plugins
*/
@Deprecated
public PluginClassLoader(final JavaPluginLoader loader, final URL[] urls, final ClassLoader parent) { public PluginClassLoader(final JavaPluginLoader loader, final URL[] urls, final ClassLoader parent) {
this(loader, urls, parent, null, null, null, null);
}
public PluginClassLoader(final JavaPluginLoader loader, final URL[] urls, final ClassLoader parent, final Server server, final PluginDescriptionFile description, final File dataFolder, final File file) {
super(urls, parent); super(urls, parent);
this.loader = loader; this.loader = loader;
this.server = server;
this.description = description;
this.dataFolder = dataFolder;
this.file = file;
} }
@Override @Override
@ -54,4 +75,13 @@ public class PluginClassLoader extends URLClassLoader {
public Set<String> getClasses() { public Set<String> getClasses() {
return classes.keySet(); return classes.keySet();
} }
void initialize(JavaPlugin javaPlugin) {
Validate.notNull(javaPlugin, "Initializing plugin cannot be null");
Validate.isTrue(javaPlugin.getClass().getClassLoader() == this, "Cannot initialize plugin outside of this class loader");
if (server != null && description != null && dataFolder != null && file != null) {
javaPlugin.initialize(loader, server, description, dataFolder, file, this);
}
}
} }