diff options
author | aclement <aclement> | 2010-05-03 17:47:58 +0000 |
---|---|---|
committer | aclement <aclement> | 2010-05-03 17:47:58 +0000 |
commit | 999f15a41b72aa10f05dd8762f70a2f4de00f30d (patch) | |
tree | cdee9bdab799acde1f7683fea960403dccf4cbee /loadtime/src/org/aspectj/weaver | |
parent | 728ecb8806b154c20f7b1248ae994a93a514f7a2 (diff) | |
download | aspectj-999f15a41b72aa10f05dd8762f70a2f4de00f30d.tar.gz aspectj-999f15a41b72aa10f05dd8762f70a2f4de00f30d.zip |
122460
Diffstat (limited to 'loadtime/src/org/aspectj/weaver')
-rw-r--r-- | loadtime/src/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptor.java | 61 | ||||
-rw-r--r-- | loadtime/src/org/aspectj/weaver/loadtime/DefaultWeavingContext.java | 73 |
2 files changed, 71 insertions, 63 deletions
diff --git a/loadtime/src/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptor.java b/loadtime/src/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptor.java index d531105bd..0db0220c4 100644 --- a/loadtime/src/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptor.java +++ b/loadtime/src/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptor.java @@ -78,10 +78,10 @@ public class ClassLoaderWeavingAdaptor extends WeavingAdaptor { private List<String> includeExactName = new ArrayList<String>(); private boolean includeStar = false; - private List m_aspectExcludeTypePattern = new ArrayList(); - private List m_aspectExcludeStartsWith = new ArrayList(); - private List m_aspectIncludeTypePattern = new ArrayList(); - private List m_aspectIncludeStartsWith = new ArrayList(); + private List<TypePattern> m_aspectExcludeTypePattern = new ArrayList<TypePattern>(); + private List<String> m_aspectExcludeStartsWith = new ArrayList<String>(); + private List<TypePattern> m_aspectIncludeTypePattern = new ArrayList<TypePattern>(); + private List<String> m_aspectIncludeStartsWith = new ArrayList<String>(); private StringBuffer namespace; private IWeavingContext weavingContext; @@ -201,12 +201,12 @@ public class ClassLoaderWeavingAdaptor extends WeavingAdaptor { * @param weaver * @param loader */ - List parseDefinitions(final ClassLoader loader) { + List<Definition> parseDefinitions(final ClassLoader loader) { if (trace.isTraceEnabled()) { trace.enter("parseDefinitions", this); } - List definitions = new ArrayList(); + List<Definition> definitions = new ArrayList<Definition>(); try { info("register classloader " + getClassLoaderName(loader)); // TODO av underoptimized: we will parse each XML once per CL that see it @@ -242,12 +242,12 @@ public class ClassLoaderWeavingAdaptor extends WeavingAdaptor { error("malformed definition url: " + nextDefinition); } } else { - Enumeration xmls = weavingContext.getResources(nextDefinition); + Enumeration<URL> xmls = weavingContext.getResources(nextDefinition); // System.out.println("? registerDefinitions: found-aop.xml=" + xmls.hasMoreElements() + ", loader=" + loader); - Set seenBefore = new HashSet(); + Set<URL> seenBefore = new HashSet<URL>(); while (xmls.hasMoreElements()) { - URL xml = (URL) xmls.nextElement(); + URL xml = xmls.nextElement(); if (trace.isTraceEnabled()) { trace.event("parseDefinitions", this, xml); } @@ -275,7 +275,7 @@ public class ClassLoaderWeavingAdaptor extends WeavingAdaptor { return definitions; } - private boolean registerDefinitions(final BcelWeaver weaver, final ClassLoader loader, List definitions) { + private boolean registerDefinitions(final BcelWeaver weaver, final ClassLoader loader, List<Definition> definitions) { if (trace.isTraceEnabled()) { trace.enter("registerDefinitions", this, definitions); } @@ -388,12 +388,10 @@ public class ClassLoaderWeavingAdaptor extends WeavingAdaptor { // TODO proceedOnError option } - private void registerAspectExclude(final BcelWeaver weaver, final ClassLoader loader, final List definitions) { + private void registerAspectExclude(final BcelWeaver weaver, final ClassLoader loader, final List<Definition> definitions) { String fastMatchInfo = null; - for (Iterator iterator = definitions.iterator(); iterator.hasNext();) { - Definition definition = (Definition) iterator.next(); - for (Iterator iterator1 = definition.getAspectExcludePatterns().iterator(); iterator1.hasNext();) { - String exclude = (String) iterator1.next(); + for (Definition definition : definitions) { + for (String exclude : definition.getAspectExcludePatterns()) { TypePattern excludePattern = new PatternParser(exclude).parseTypePattern(); m_aspectExcludeTypePattern.add(excludePattern); fastMatchInfo = looksLikeStartsWith(exclude); @@ -404,12 +402,10 @@ public class ClassLoaderWeavingAdaptor extends WeavingAdaptor { } } - private void registerAspectInclude(final BcelWeaver weaver, final ClassLoader loader, final List definitions) { + private void registerAspectInclude(final BcelWeaver weaver, final ClassLoader loader, final List<Definition> definitions) { String fastMatchInfo = null; - for (Iterator iterator = definitions.iterator(); iterator.hasNext();) { - Definition definition = (Definition) iterator.next(); - for (Iterator iterator1 = definition.getAspectIncludePatterns().iterator(); iterator1.hasNext();) { - String include = (String) iterator1.next(); + for (Definition definition : definitions) { + for (String include : definition.getAspectIncludePatterns()) { TypePattern includePattern = new PatternParser(include).parseTypePattern(); m_aspectIncludeTypePattern.add(includePattern); fastMatchInfo = looksLikeStartsWith(include); @@ -438,7 +434,7 @@ public class ClassLoaderWeavingAdaptor extends WeavingAdaptor { * @param loader * @param definitions */ - private boolean registerAspects(final BcelWeaver weaver, final ClassLoader loader, final List definitions) { + private boolean registerAspects(final BcelWeaver weaver, final ClassLoader loader, final List<Definition> definitions) { if (trace.isTraceEnabled()) { trace.enter("registerAspects", this, new Object[] { weaver, loader, definitions }); } @@ -449,21 +445,25 @@ public class ClassLoaderWeavingAdaptor extends WeavingAdaptor { // iterate aspectClassNames // exclude if in any of the exclude list - for (Iterator iterator = definitions.iterator(); iterator.hasNext();) { - Definition definition = (Definition) iterator.next(); - for (Iterator aspects = definition.getAspectClassNames().iterator(); aspects.hasNext();) { - String aspectClassName = (String) aspects.next(); + for (Definition definition : definitions) { + for (String aspectClassName : definition.getAspectClassNames()) { if (acceptAspect(aspectClassName)) { info("register aspect " + aspectClassName); // System.err.println("? ClassLoaderWeavingAdaptor.registerAspects() aspectName=" + aspectClassName + // ", loader=" + loader + ", bundle=" + weavingContext.getClassLoaderName()); - /* ResolvedType aspect = */weaver.addLibraryAspect(aspectClassName); + // ResolvedType aspect = + weaver.addLibraryAspect(aspectClassName); // generate key for SC if (namespace == null) { namespace = new StringBuffer(aspectClassName); } else { - namespace = namespace.append(";" + aspectClassName); + namespace = namespace.append(";").append(aspectClassName); + } + + String definedScope = definition.getScopeForAspect(aspectClassName); + if (definedScope != null) { + ((BcelWorld) weaver.getWorld()).addScopedAspect(aspectClassName, definedScope); } } else { // warn("aspect excluded: " + aspectClassName); @@ -474,8 +474,7 @@ public class ClassLoaderWeavingAdaptor extends WeavingAdaptor { // iterate concreteAspects // exclude if in any of the exclude list - note that the user defined name matters for that to happen - for (Iterator iterator = definitions.iterator(); iterator.hasNext();) { - Definition definition = (Definition) iterator.next(); + for (Definition definition : definitions) { for (Definition.ConcreteAspect concreteAspect : definition.getConcreteAspects()) { if (acceptAspect(concreteAspect.name)) { info("define aspect " + concreteAspect.name); @@ -859,13 +858,13 @@ public class ClassLoaderWeavingAdaptor extends WeavingAdaptor { // EXCLUDE: if one match then reject String fastClassName = aspectClassName.replace('/', '.').replace('.', '$'); for (int i = 0; i < m_aspectExcludeStartsWith.size(); i++) { - if (fastClassName.startsWith((String) m_aspectExcludeStartsWith.get(i))) { + if (fastClassName.startsWith(m_aspectExcludeStartsWith.get(i))) { return false; } } // INCLUDE: if one match then accept for (int i = 0; i < m_aspectIncludeStartsWith.size(); i++) { - if (fastClassName.startsWith((String) m_aspectIncludeStartsWith.get(i))) { + if (fastClassName.startsWith(m_aspectIncludeStartsWith.get(i))) { return true; } } diff --git a/loadtime/src/org/aspectj/weaver/loadtime/DefaultWeavingContext.java b/loadtime/src/org/aspectj/weaver/loadtime/DefaultWeavingContext.java index 67951c97f..0af75265c 100644 --- a/loadtime/src/org/aspectj/weaver/loadtime/DefaultWeavingContext.java +++ b/loadtime/src/org/aspectj/weaver/loadtime/DefaultWeavingContext.java @@ -17,6 +17,7 @@ import java.util.Enumeration; import java.util.List; import org.aspectj.weaver.bcel.BcelWeakClassLoaderReference; +import org.aspectj.weaver.loadtime.definition.Definition; import org.aspectj.weaver.tools.Trace; import org.aspectj.weaver.tools.TraceFactory; import org.aspectj.weaver.tools.WeavingAdaptor; @@ -34,8 +35,8 @@ public class DefaultWeavingContext implements IWeavingContext { private static Trace trace = TraceFactory.getTraceFactory().getTrace(DefaultWeavingContext.class); /** - * Construct a new WeavingContext to use the specified ClassLoader - * This is the constructor which should be used. + * Construct a new WeavingContext to use the specified ClassLoader This is the constructor which should be used. + * * @param loader */ public DefaultWeavingContext(ClassLoader loader) { @@ -62,11 +63,11 @@ public class DefaultWeavingContext implements IWeavingContext { */ public String getClassLoaderName() { ClassLoader loader = getClassLoader(); - return ((loader!=null)?loader.getClass().getName()+"@"+Integer.toHexString(System.identityHashCode(loader)):"null"); + return ((loader != null) ? loader.getClass().getName() + "@" + Integer.toHexString(System.identityHashCode(loader)) + : "null"); } - - public ClassLoader getClassLoader() { + public ClassLoader getClassLoader() { return loaderRef.getClassLoader(); } @@ -74,55 +75,63 @@ public class DefaultWeavingContext implements IWeavingContext { * @return filename */ public String getFile(URL url) { - return url.getFile(); + return url.getFile(); } /** - * @return unqualifiedclassname@hashcode + * @return unqualifiedclassname@hashcode */ - public String getId () { + public String getId() { if (shortName == null) { - shortName = getClassLoaderName().replace('$','.'); + shortName = getClassLoaderName().replace('$', '.'); int index = shortName.lastIndexOf("."); - if (index!=-1) { + if (index != -1) { shortName = shortName.substring(index + 1); } } return shortName; } - - public String getSuffix () { + + public String getSuffix() { return getClassLoaderName(); } public boolean isLocallyDefined(String classname) { - String asResource = classname.replace('.', '/').concat(".class"); - ClassLoader loader = getClassLoader(); - URL localURL = loader.getResource(asResource); - if (localURL == null) return false; + String asResource = classname.replace('.', '/').concat(".class"); + ClassLoader loader = getClassLoader(); + URL localURL = loader.getResource(asResource); + if (localURL == null) { + return false; + } boolean isLocallyDefined = true; - - ClassLoader parent = loader.getParent(); - if (parent != null) { - URL parentURL = parent.getResource(asResource); - if (localURL.equals(parentURL)) isLocallyDefined = false; - } - return isLocallyDefined; + + ClassLoader parent = loader.getParent(); + if (parent != null) { + URL parentURL = parent.getResource(asResource); + if (localURL.equals(parentURL)) { + isLocallyDefined = false; + } + } + return isLocallyDefined; } /** * Simply call weaving adaptor back to parse aop.xml - * + * * @param weaver * @param loader */ - public List getDefinitions(final ClassLoader loader, final WeavingAdaptor adaptor) { - if (trace.isTraceEnabled()) trace.enter("getDefinitions", this, new Object[] { "goo", adaptor }); - - List definitions = ((ClassLoaderWeavingAdaptor)adaptor).parseDefinitions(loader); - - if (trace.isTraceEnabled()) trace.exit("getDefinitions",definitions); - return definitions; - } + public List<Definition> getDefinitions(final ClassLoader loader, final WeavingAdaptor adaptor) { + if (trace.isTraceEnabled()) { + trace.enter("getDefinitions", this, new Object[] { "goo", adaptor }); + } + + List<Definition> definitions = ((ClassLoaderWeavingAdaptor) adaptor).parseDefinitions(loader); + + if (trace.isTraceEnabled()) { + trace.exit("getDefinitions", definitions); + } + return definitions; + } } |