aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoraclement <aclement>2006-11-20 13:20:41 +0000
committeraclement <aclement>2006-11-20 13:20:41 +0000
commite8d2556d9448375fcf578695c082f81aa604fddb (patch)
tree8dc6bcc91cf70cc383d6be8a2876625556f2b273
parent7143428801aa03299b6ff1651df7012097024576 (diff)
downloadaspectj-e8d2556d9448375fcf578695c082f81aa604fddb.tar.gz
aspectj-e8d2556d9448375fcf578695c082f81aa604fddb.zip
fix for 165148 - don't resolve things you are 99 percent sure won't be found
-rw-r--r--loadtime/src/org/aspectj/weaver/loadtime/ConcreteAspectCodeGen.java13
1 files changed, 7 insertions, 6 deletions
diff --git a/loadtime/src/org/aspectj/weaver/loadtime/ConcreteAspectCodeGen.java b/loadtime/src/org/aspectj/weaver/loadtime/ConcreteAspectCodeGen.java
index 2b3a36381..89dc420fb 100644
--- a/loadtime/src/org/aspectj/weaver/loadtime/ConcreteAspectCodeGen.java
+++ b/loadtime/src/org/aspectj/weaver/loadtime/ConcreteAspectCodeGen.java
@@ -24,6 +24,7 @@ import org.aspectj.apache.bcel.generic.annotation.SimpleElementValueGen;
import org.aspectj.bridge.IMessage;
import org.aspectj.bridge.Message;
import org.aspectj.weaver.AnnotationX;
+import org.aspectj.weaver.ReferenceType;
import org.aspectj.weaver.ResolvedMember;
import org.aspectj.weaver.ResolvedType;
import org.aspectj.weaver.UnresolvedType;
@@ -107,8 +108,10 @@ public class ConcreteAspectCodeGen {
}
// name must be undefined so far
- ResolvedType current = m_world.resolve(m_concreteAspect.name, true);
- if (!current.isMissing()) {
+ // TODO only convert the name to signature once, probably earlier than this
+ ResolvedType current = m_world.lookupBySignature(UnresolvedType.forName(m_concreteAspect.name).getSignature());
+
+ if (current!=null && !current.isMissing()) {
reportError("Attempt to concretize but chosen aspect name already defined: " + stringify());
return false;
}
@@ -375,10 +378,8 @@ public class ConcreteAspectCodeGen {
}
// handle the perClause
- BcelPerClauseAspectAdder perClauseMunger = new BcelPerClauseAspectAdder(
- ResolvedType.forName(m_concreteAspect.name).resolve(m_world),
- m_perClause.getKind()
- );
+ ReferenceType rt = new ReferenceType(ResolvedType.forName(m_concreteAspect.name).getSignature(),m_world);
+ BcelPerClauseAspectAdder perClauseMunger = new BcelPerClauseAspectAdder(rt,m_perClause.getKind());
perClauseMunger.forceMunge(cg, false);
//TODO AV - unsafe cast