summaryrefslogtreecommitdiffstats
path: root/EssentialsExtra/src
diff options
context:
space:
mode:
authormd_5 <md_5@bigpond.com>2012-10-07 15:37:27 +1100
committermd_5 <md_5@bigpond.com>2012-10-07 15:37:27 +1100
commit2c478072a2e184c4526a6edf9075d14cd3c7de7f (patch)
treee4ff1c76c280fe6c82c2d055a7671cc5c9c8abdf /EssentialsExtra/src
parentdf1007baff1614652a17db133ac7906b4c925d01 (diff)
downloadEssentials-2c478072a2e184c4526a6edf9075d14cd3c7de7f.tar
Essentials-2c478072a2e184c4526a6edf9075d14cd3c7de7f.tar.gz
Essentials-2c478072a2e184c4526a6edf9075d14cd3c7de7f.tar.lz
Essentials-2c478072a2e184c4526a6edf9075d14cd3c7de7f.tar.xz
Essentials-2c478072a2e184c4526a6edf9075d14cd3c7de7f.zip
Save commands that are in the jar by default, print commands on load. Should work, havent tested.
Diffstat (limited to 'EssentialsExtra/src')
-rw-r--r--EssentialsExtra/src/net/ess3/extra/EssentialsExtra.java51
1 files changed, 46 insertions, 5 deletions
diff --git a/EssentialsExtra/src/net/ess3/extra/EssentialsExtra.java b/EssentialsExtra/src/net/ess3/extra/EssentialsExtra.java
index a1504b9cb..75c0bd7fd 100644
--- a/EssentialsExtra/src/net/ess3/extra/EssentialsExtra.java
+++ b/EssentialsExtra/src/net/ess3/extra/EssentialsExtra.java
@@ -1,9 +1,15 @@
package net.ess3.extra;
import java.io.File;
-import java.net.MalformedURLException;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
import java.net.URL;
import java.net.URLClassLoader;
+import java.util.Enumeration;
+import java.util.jar.JarEntry;
+import java.util.jar.JarFile;
import java.util.logging.Level;
import net.ess3.api.ICommandHandler;
import net.ess3.api.IEssentials;
@@ -18,7 +24,6 @@ public class EssentialsExtra extends JavaPlugin
{
private IEssentials ess;
private ICommandHandler handler;
- private ClassLoader loader;
@Override
public void onLoad()
@@ -29,23 +34,59 @@ public class EssentialsExtra extends JavaPlugin
@Override
public void onEnable()
{
- handler = new EssentialsCommandHandler(loader, "Command", "essentials.", ess);
File commandDir = new File(ess.getPlugin().getDataFolder(), "extras");
commandDir.mkdir();
+
URL[] urls = null;
try
{
+ JarFile jar = new JarFile(getFile());
+ Enumeration<JarEntry> entries = jar.entries();
+ while (entries.hasMoreElements())
+ {
+ JarEntry entry = entries.nextElement();
+ String name = entry.getName();
+ if (name.startsWith("Command") && name.endsWith(".class"))
+ {
+ File outFile = new File(commandDir, name);
+ if (!outFile.exists())
+ {
+ InputStream is = jar.getInputStream(entry);
+ OutputStream os = new FileOutputStream(outFile);
+ byte[] buffer = new byte[4096];
+ int length;
+ while ((length = is.read(buffer)) > 0)
+ {
+ os.write(buffer, 0, length);
+ }
+ os.close();
+ is.close();
+
+ }
+ }
+ }
urls = new URL[]
{
commandDir.toURI().toURL()
};
}
- catch (MalformedURLException ex)
+ catch (IOException ex)
{
getLogger().log(Level.SEVERE, "Could not get extra command dir", ex);
getServer().getPluginManager().disablePlugin(this);
}
- loader = new URLClassLoader(urls, getClassLoader());
+
+ for (File file : commandDir.listFiles())
+ {
+ String name = file.getName();
+ if (name.startsWith("Command") && name.endsWith(".class"))
+ {
+ getLogger().info("Loaded command " + name.substring(0, name.length() - 7));
+ }
+ }
+
+ ClassLoader loader = new URLClassLoader(urls, getClassLoader());
+ handler = new EssentialsCommandHandler(loader, "Command", "essentials.", ess);
}
@Override