diff options
author | aclement <aclement> | 2009-04-27 22:15:30 +0000 |
---|---|---|
committer | aclement <aclement> | 2009-04-27 22:15:30 +0000 |
commit | 5e8ba5a1320f80712cd9aabcdbd52af8ee92dd37 (patch) | |
tree | edd098ba53a744f86efabb7210352e663330e457 /loadtime | |
parent | 42b451fbb6dd1306a3fe5da7000d3d02f1f21b0a (diff) | |
download | aspectj-5e8ba5a1320f80712cd9aabcdbd52af8ee92dd37.tar.gz aspectj-5e8ba5a1320f80712cd9aabcdbd52af8ee92dd37.zip |
guard for null - it may not yet have been setup
Diffstat (limited to 'loadtime')
-rw-r--r-- | loadtime/src/org/aspectj/weaver/loadtime/WeavingURLClassLoader.java | 195 |
1 files changed, 100 insertions, 95 deletions
diff --git a/loadtime/src/org/aspectj/weaver/loadtime/WeavingURLClassLoader.java b/loadtime/src/org/aspectj/weaver/loadtime/WeavingURLClassLoader.java index e79163bd7..eab084fb6 100644 --- a/loadtime/src/org/aspectj/weaver/loadtime/WeavingURLClassLoader.java +++ b/loadtime/src/org/aspectj/weaver/loadtime/WeavingURLClassLoader.java @@ -33,70 +33,72 @@ import org.aspectj.weaver.tools.WeavingClassLoader; public class WeavingURLClassLoader extends ExtensibleURLClassLoader implements WeavingClassLoader { - public static final String WEAVING_CLASS_PATH = "aj.class.path"; - public static final String WEAVING_ASPECT_PATH = "aj.aspect.path"; - + public static final String WEAVING_CLASS_PATH = "aj.class.path"; + public static final String WEAVING_ASPECT_PATH = "aj.aspect.path"; + private URL[] aspectURLs; private WeavingAdaptor adaptor; private boolean initializingAdaptor; - private Map generatedClasses = new HashMap(); /* String -> byte[] */ - + private Map generatedClasses = new HashMap(); /* String -> byte[] */ + private static Trace trace = TraceFactory.getTraceFactory().getTrace(WeavingURLClassLoader.class); /* - * This constructor is needed when using "-Djava.system.class.loader". + * This constructor is needed when using "-Djava.system.class.loader". */ - public WeavingURLClassLoader (ClassLoader parent) { - this(getURLs(getClassPath()),getURLs(getAspectPath()),parent); -// System.out.println("? WeavingURLClassLoader.WeavingURLClassLoader()"); + public WeavingURLClassLoader(ClassLoader parent) { + this(getURLs(getClassPath()), getURLs(getAspectPath()), parent); + // System.out.println("? WeavingURLClassLoader.WeavingURLClassLoader()"); } - - public WeavingURLClassLoader (URL[] urls, ClassLoader parent) { - super(urls,parent); - if (trace.isTraceEnabled()) trace.enter("<init>",this,new Object[] { urls, parent }); -// System.out.println("WeavingURLClassLoader.WeavingURLClassLoader()"); - if (trace.isTraceEnabled()) trace.exit("<init>"); + + public WeavingURLClassLoader(URL[] urls, ClassLoader parent) { + super(urls, parent); + if (trace.isTraceEnabled()) + trace.enter("<init>", this, new Object[] { urls, parent }); + // System.out.println("WeavingURLClassLoader.WeavingURLClassLoader()"); + if (trace.isTraceEnabled()) + trace.exit("<init>"); } - - public WeavingURLClassLoader (URL[] classURLs, URL[] aspectURLs, ClassLoader parent) { - super(classURLs,parent); -// System.out.println("> WeavingURLClassLoader.WeavingURLClassLoader() classURLs=" + Arrays.asList(classURLs)); + + public WeavingURLClassLoader(URL[] classURLs, URL[] aspectURLs, ClassLoader parent) { + super(classURLs, parent); + // System.out.println("> WeavingURLClassLoader.WeavingURLClassLoader() classURLs=" + Arrays.asList(classURLs)); this.aspectURLs = aspectURLs; - - /* If either we nor our parent is using an ASPECT_PATH use a new-style - * adaptor - */ + + /* + * If either we nor our parent is using an ASPECT_PATH use a new-style adaptor + */ if (this.aspectURLs.length > 0 || getParent() instanceof WeavingClassLoader) { try { adaptor = new WeavingAdaptor(this); - } - catch (ExceptionInInitializerError ex) { + } catch (ExceptionInInitializerError ex) { ex.printStackTrace(System.out); throw ex; } } -// System.out.println("< WeavingURLClassLoader.WeavingURLClassLoader() adaptor=" + adaptor); + // System.out.println("< WeavingURLClassLoader.WeavingURLClassLoader() adaptor=" + adaptor); } - - private static String getAspectPath () { - return System.getProperty(WEAVING_ASPECT_PATH,""); + + private static String getAspectPath() { + return System.getProperty(WEAVING_ASPECT_PATH, ""); } - - private static String getClassPath () { - return System.getProperty(WEAVING_CLASS_PATH,""); + + private static String getClassPath() { + return System.getProperty(WEAVING_CLASS_PATH, ""); } - - private static URL[] getURLs (String path) { + + private static URL[] getURLs(String path) { List urlList = new ArrayList(); - for (StringTokenizer t = new StringTokenizer(path,File.pathSeparator); - t.hasMoreTokens();) { + for (StringTokenizer t = new StringTokenizer(path, File.pathSeparator); t.hasMoreTokens();) { File f = new File(t.nextToken().trim()); try { if (f.exists()) { URL url = f.toURL(); - if (url != null) urlList.add(url); + if (url != null) + urlList.add(url); } - } catch (MalformedURLException e) {} + } catch (MalformedURLException e) { + } } URL[] urls = new URL[urlList.size()]; @@ -105,55 +107,58 @@ public class WeavingURLClassLoader extends ExtensibleURLClassLoader implements W } protected void addURL(URL url) { + if (adaptor == null) { + createAdaptor(); + } adaptor.addURL(url); super.addURL(url); } /** - * Override to weave class using WeavingAdaptor + * Override to weave class using WeavingAdaptor */ protected Class defineClass(String name, byte[] b, CodeSource cs) throws IOException { - if (trace.isTraceEnabled()) trace.enter("defineClass",this,new Object[] { name, b, cs }); -// System.err.println("? WeavingURLClassLoader.defineClass(" + name + ", [" + b.length + "])"); + if (trace.isTraceEnabled()) + trace.enter("defineClass", this, new Object[] { name, b, cs }); + // System.err.println("? WeavingURLClassLoader.defineClass(" + name + ", [" + b.length + "])"); /* Avoid recursion during adaptor initialization */ if (!initializingAdaptor) { - + /* Need to defer creation because of possible recursion during constructor execution */ if (adaptor == null && !initializingAdaptor) { createAdaptor(); } - + try { - b = adaptor.weaveClass(name,b,false); - } - catch (AbortException ex) { - trace.error("defineClass",ex); - throw ex; - } - catch (Throwable th) { - trace.error("defineClass",th); + b = adaptor.weaveClass(name, b, false); + } catch (AbortException ex) { + trace.error("defineClass", ex); + throw ex; + } catch (Throwable th) { + trace.error("defineClass", th); } } Class clazz = super.defineClass(name, b, cs); - if (trace.isTraceEnabled()) trace.exit("defineClass",clazz); + if (trace.isTraceEnabled()) + trace.exit("defineClass", clazz); return clazz; } - - private void createAdaptor () { - DefaultWeavingContext weavingContext = new DefaultWeavingContext (this) { + + private void createAdaptor() { + DefaultWeavingContext weavingContext = new DefaultWeavingContext(this) { /* Ensures consistent LTW messages for testing */ public String getClassLoaderName() { ClassLoader loader = getClassLoader(); return loader.getClass().getName(); } - + }; - + ClassLoaderWeavingAdaptor clwAdaptor = new ClassLoaderWeavingAdaptor(); initializingAdaptor = true; - clwAdaptor.initialize(this,weavingContext); + clwAdaptor.initialize(this, weavingContext); initializingAdaptor = false; adaptor = clwAdaptor; } @@ -161,14 +166,14 @@ public class WeavingURLClassLoader extends ExtensibleURLClassLoader implements W /** * Override to find classes generated by WeavingAdaptor */ - protected byte[] getBytes (String name) throws IOException { + protected byte[] getBytes(String name) throws IOException { byte[] bytes = super.getBytes(name); - + if (bytes == null) { -// return adaptor.findClass(name); - return (byte[])generatedClasses.remove(name); + // return adaptor.findClass(name); + return (byte[]) generatedClasses.remove(name); } - + return bytes; } @@ -179,39 +184,39 @@ public class WeavingURLClassLoader extends ExtensibleURLClassLoader implements W return aspectURLs; } - public void acceptClass (String name, byte[] bytes) { - generatedClasses.put(name,bytes); + public void acceptClass(String name, byte[] bytes) { + generatedClasses.put(name, bytes); } -// protected synchronized Class loadClass(String name, boolean resolve) throws ClassNotFoundException { -// System.err.println("> WeavingURLClassLoader.loadClass() name=" + name); -// Class clazz= super.loadClass(name, resolve); -// System.err.println("< WeavingURLClassLoader.loadClass() clazz=" + clazz + ", loader=" + clazz.getClassLoader()); -// return clazz; -// } - -// private interface ClassPreProcessorAdaptor extends ClassPreProcessor { -// public void addURL(URL url); -// } -// -// private class WeavingAdaptorPreProcessor implements ClassPreProcessorAdaptor { -// -// private WeavingAdaptor adaptor; -// -// public WeavingAdaptorPreProcessor (WeavingClassLoader wcl) { -// adaptor = new WeavingAdaptor(wcl); -// } -// -// public void initialize() { -// } -// -// public byte[] preProcess(String className, byte[] bytes, ClassLoader classLoader) { -// return adaptor.weaveClass(className,bytes); -// } -// -// public void addURL(URL url) { -// -// } -// } + // protected synchronized Class loadClass(String name, boolean resolve) throws ClassNotFoundException { + // System.err.println("> WeavingURLClassLoader.loadClass() name=" + name); + // Class clazz= super.loadClass(name, resolve); + // System.err.println("< WeavingURLClassLoader.loadClass() clazz=" + clazz + ", loader=" + clazz.getClassLoader()); + // return clazz; + // } + + // private interface ClassPreProcessorAdaptor extends ClassPreProcessor { + // public void addURL(URL url); + // } + // + // private class WeavingAdaptorPreProcessor implements ClassPreProcessorAdaptor { + // + // private WeavingAdaptor adaptor; + // + // public WeavingAdaptorPreProcessor (WeavingClassLoader wcl) { + // adaptor = new WeavingAdaptor(wcl); + // } + // + // public void initialize() { + // } + // + // public byte[] preProcess(String className, byte[] bytes, ClassLoader classLoader) { + // return adaptor.weaveClass(className,bytes); + // } + // + // public void addURL(URL url) { + // + // } + // } } |