aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/BcelShadow.java17
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/TypeAnnotationAccessVar.java32
-rw-r--r--weaver/src/org/aspectj/weaver/patterns/ArgsAnnotationPointcut.java16
-rw-r--r--weaver/src/org/aspectj/weaver/patterns/BindingAnnotationTypePattern.java10
4 files changed, 43 insertions, 32 deletions
diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java b/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java
index 7e4b93135..9427e1c3e 100644
--- a/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java
+++ b/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java
@@ -889,8 +889,12 @@ public class BcelShadow extends Shadow {
if (!hasThis()) {
throw new IllegalStateException("no this");
}
- initializeThisAnnotationVars();
- return (Var) thisAnnotationVars.get(forAnnotationType);
+ initializeThisAnnotationVars(); // FIXME ASC Why bother with this if we always return one?
+ // Even if we can't find one, we have to return one as we might have this annotation at runtime
+ Var v = (Var) thisAnnotationVars.get(forAnnotationType);
+ if (v==null)
+ v = new TypeAnnotationAccessVar(forAnnotationType.resolve(world),(BcelVar)getThisVar());
+ return v;
}
public Var getTargetVar() {
if (!hasTarget()) {
@@ -903,7 +907,7 @@ public class BcelShadow extends Shadow {
if (!hasTarget()) {
throw new IllegalStateException("no target");
}
- initializeTargetAnnotationVars();
+ initializeTargetAnnotationVars(); // FIXME ASC why bother with this if we always return one?
Var v =(Var) targetAnnotationVars.get(forAnnotationType);
// Even if we can't find one, we have to return one as we might have this annotation at runtime
if (v==null)
@@ -916,7 +920,11 @@ public class BcelShadow extends Shadow {
}
public Var getArgAnnotationVar(int i,TypeX forAnnotationType) {
initializeArgAnnotationVars();
- return (Var) argAnnotationVars[i].get(forAnnotationType);
+
+ Var v= (Var) argAnnotationVars[i].get(forAnnotationType);
+ if (v==null)
+ v = new TypeAnnotationAccessVar(forAnnotationType.resolve(world),(BcelVar)getArgVar(i));
+ return v;
}
public Var getKindedAnnotationVar(TypeX forAnnotationType) {
initializeKindedAnnotationVars();
@@ -1296,6 +1304,7 @@ public class BcelShadow extends Shadow {
argAnnotationVars = new Map[numArgs];
for (int i = 0; i < argAnnotationVars.length; i++) {
argAnnotationVars[i] = new HashMap();
+ //FIXME ASC Fill this in
// populate
}
}
diff --git a/weaver/src/org/aspectj/weaver/bcel/TypeAnnotationAccessVar.java b/weaver/src/org/aspectj/weaver/bcel/TypeAnnotationAccessVar.java
index fed60896b..c30e4ba58 100644
--- a/weaver/src/org/aspectj/weaver/bcel/TypeAnnotationAccessVar.java
+++ b/weaver/src/org/aspectj/weaver/bcel/TypeAnnotationAccessVar.java
@@ -1,5 +1,5 @@
/* *******************************************************************
- * Copyright (c) 2002 Palo Alto Research Center, Incorporated (PARC).
+ * Copyright (c) 2005
* All rights reserved.
* This program and the accompanying materials are made available
* under the terms of the Common Public License v1.0
@@ -7,7 +7,7 @@
* http://www.eclipse.org/legal/cpl-v10.html
*
* Contributors:
- * PARC initial implementation
+ * Andy Clement initial implementation
* ******************************************************************/
@@ -19,37 +19,25 @@ import org.aspectj.apache.bcel.generic.InstructionFactory;
import org.aspectj.apache.bcel.generic.InstructionList;
import org.aspectj.apache.bcel.generic.ObjectType;
import org.aspectj.apache.bcel.generic.Type;
-import org.aspectj.weaver.Member;
import org.aspectj.weaver.ResolvedTypeX;
import org.aspectj.weaver.TypeX;
/**
+ * Used for @this() @target() @args() - represents accessing an annotated
+ * 'thing'. Main use is to create the instructions that retrieve the
+ * annotation from the 'thing' - see createLoadInstructions()
*/
public class TypeAnnotationAccessVar extends BcelVar {
-
- private Member stackField;
- private int index;
- BcelVar target;
-
- /**
- * @param type The type to convert to from Object
- * @param stackField the member containing the CFLOW_STACK_TYPE
- * @param index yeah yeah
- */
- public TypeAnnotationAccessVar(ResolvedTypeX type, Member stackField, int index) {
- super(type, 0);
- this.stackField = stackField;
- this.index = index;
- }
+ private BcelVar target;
- public TypeAnnotationAccessVar(ResolvedTypeX type,BcelVar theTargetIsStoredHere) {
+ public TypeAnnotationAccessVar(ResolvedTypeX type,BcelVar theAnnotatedTargetIsStoredHere) {
super(type,0);
- target = theTargetIsStoredHere;
+ target = theAnnotatedTargetIsStoredHere;
}
public String toString() {
- return "TypeAnnotationAccessVar(" + getType() + " " + stackField + "." + index + ")";
+ return "TypeAnnotationAccessVar(" + getType() + ")";
}
public Instruction createLoad(InstructionFactory fact) {
@@ -71,7 +59,7 @@ public class TypeAnnotationAccessVar extends BcelVar {
InstructionList il = new InstructionList();
Type jlClass = BcelWorld.makeBcelType(TypeX.JAVA_LANG_CLASS);
Type jlaAnnotation = BcelWorld.makeBcelType(TypeX.forSignature("Ljava.lang.annotation.Annotation;"));
- il.append(target.createLoad(fact));
+ il.append(target.createLoad(fact));
il.append(fact.createInvoke("java/lang/Object","getClass",jlClass,new Type[]{},Constants.INVOKEVIRTUAL));
il.append(fact.createConstant(new ObjectType(toType.getClassName())));
il.append(fact.createInvoke("java/lang/Class","getAnnotation",jlaAnnotation,new Type[]{jlClass},Constants.INVOKEVIRTUAL));
diff --git a/weaver/src/org/aspectj/weaver/patterns/ArgsAnnotationPointcut.java b/weaver/src/org/aspectj/weaver/patterns/ArgsAnnotationPointcut.java
index ff3336d62..5ba432e81 100644
--- a/weaver/src/org/aspectj/weaver/patterns/ArgsAnnotationPointcut.java
+++ b/weaver/src/org/aspectj/weaver/patterns/ArgsAnnotationPointcut.java
@@ -29,6 +29,7 @@ import org.aspectj.weaver.VersionedDataInputStream;
import org.aspectj.weaver.WeaverMessages;
import org.aspectj.weaver.ast.Literal;
import org.aspectj.weaver.ast.Test;
+import org.aspectj.weaver.ast.Var;
/**
* @author colyer
@@ -136,15 +137,22 @@ public class ArgsAnnotationPointcut extends NameBindingPointcut {
WeaverMessages.format(WeaverMessages.CANT_FIND_TYPE_ARG_TYPE,argType.getName()),
"",IMessage.ERROR,shadow.getSourceLocation(),null,new ISourceLocation[]{getSourceLocation()});
}
- if (ap.matches(rArgType).alwaysTrue()) {
+ if (ap.matches(rArgType).alwaysTrue()) { // !!! ASC Can we ever take this branch?
argsIndex++;
continue;
} else {
// we need a test...
- // TODO: binding
ResolvedTypeX rAnnType = ap.annotationType.resolve(shadow.getIWorld());
- ret = Test.makeAnd(ret,Test.makeHasAnnotation(shadow.getArgVar(argsIndex),rAnnType));
- argsIndex++;
+ if (ap instanceof BindingAnnotationTypePattern) {
+ BindingAnnotationTypePattern btp = (BindingAnnotationTypePattern)ap;
+ Var annvar = shadow.getArgAnnotationVar(argsIndex,rAnnType);
+ state.set(argsIndex,annvar);
+ ret = Test.makeAnd(ret,Test.makeHasAnnotation(shadow.getArgVar(argsIndex),rAnnType));
+ argsIndex++;
+ } else {
+ ret = Test.makeAnd(ret,Test.makeHasAnnotation(shadow.getArgVar(argsIndex),rAnnType));
+ argsIndex++;
+ }
}
}
}
diff --git a/weaver/src/org/aspectj/weaver/patterns/BindingAnnotationTypePattern.java b/weaver/src/org/aspectj/weaver/patterns/BindingAnnotationTypePattern.java
index e59907592..e4040819e 100644
--- a/weaver/src/org/aspectj/weaver/patterns/BindingAnnotationTypePattern.java
+++ b/weaver/src/org/aspectj/weaver/patterns/BindingAnnotationTypePattern.java
@@ -58,8 +58,14 @@ public class BindingAnnotationTypePattern extends ExactAnnotationTypePattern imp
world.getMessageHandler().handleMessage(m);
resolved = false;
} else {
- // TO DO... get the retention policy annotation, and check the value is
- // RetentionPolicy.RUNTIME;
+ // Get the retention policy annotation, and check the value is RetentionPolicy.RUNTIME;
+ // FIXME invention required, implement this !
+// if (!annotationType.hasRuntimeRetention()) {
+// ResolvedTypeX[] allAs = annotationType.getAnnotationTypes();
+// for (int i = 0; i < allAs.length; i++) {
+// ResolvedTypeX ann = allAs[i];
+// if ()
+// }
}
}