aboutsummaryrefslogtreecommitdiffstats
path: root/weaver
diff options
context:
space:
mode:
Diffstat (limited to 'weaver')
-rw-r--r--weaver/src/org/aspectj/weaver/patterns/WildTypePattern.java140
-rw-r--r--weaver/testdata/AfterReturningFancyHelloWorld.txt1
-rw-r--r--weaver/testdata/AfterReturningHelloWorld.txt1
-rw-r--r--weaver/testdata/BeforeFancyHelloWorld.txt1
-rw-r--r--weaver/testdata/BeforeHelloWorld.txt1
-rw-r--r--weaver/testdata/dummyAspect.jarbin910 -> 911 bytes
-rw-r--r--weaver/testdata/ltw-acaspects.jarbin2568 -> 2572 bytes
-rw-r--r--weaver/testdata/ltw-aspects.jarbin1592 -> 1594 bytes
-rw-r--r--weaver/testdata/ltw-classes.jarbin1486 -> 1494 bytes
-rw-r--r--weaver/testdata/ltw-deaspects.jarbin1249 -> 1249 bytes
-rw-r--r--weaver/testdata/ltw-dwaspects.jarbin1250 -> 1253 bytes
-rw-r--r--weaver/testdata/ltw-itdaspects.jarbin5815 -> 5826 bytes
-rw-r--r--weaver/testdata/ltw-peraspects.jarbin1922 -> 1924 bytes
-rw-r--r--weaver/testdata/ltw-woven.jarbin2819 -> 2843 bytes
-rw-r--r--weaver/testdata/megatrace.jarbin5584 -> 5602 bytes
-rw-r--r--weaver/testdata/megatrace0easy.jarbin3966 -> 4002 bytes
-rw-r--r--weaver/testdata/megatrace0hard.jarbin3836 -> 3855 bytes
-rw-r--r--weaver/testdata/megatraceNoweave.jarbin3320 -> 3342 bytes
-rw-r--r--weaver/testdata/tracing.jarbin2861 -> 2871 bytes
19 files changed, 143 insertions, 1 deletions
diff --git a/weaver/src/org/aspectj/weaver/patterns/WildTypePattern.java b/weaver/src/org/aspectj/weaver/patterns/WildTypePattern.java
index a4234982f..b1fbba5ed 100644
--- a/weaver/src/org/aspectj/weaver/patterns/WildTypePattern.java
+++ b/weaver/src/org/aspectj/weaver/patterns/WildTypePattern.java
@@ -36,6 +36,102 @@ import org.aspectj.weaver.VersionedDataInputStream;
import org.aspectj.weaver.WeaverMessages;
//XXX need to use dim in matching
+/**
+ * The PatternParser always creates WildTypePatterns for type patterns in pointcut
+ * expressions (apart from *, which is sometimes directly turned into TypePattern.ANY).
+ * resolveBindings() tries to work out what we've really got and turn it into a type
+ * pattern that we can use for matching. This will normally be either an ExactTypePattern
+ * or a WildTypePattern.
+ *
+ * Here's how the process pans out for various generic and parameterized patterns:
+ * (see GenericsWildTypePatternResolvingTestCase)
+ *
+ * Foo where Foo exists and is generic
+ * Parser creates WildTypePattern namePatterns={Foo}
+ * resolveBindings resolves Foo to RT(Foo - raw)
+ * return ExactTypePattern(LFoo;)
+ *
+ * <E>... Foo<E> where Foo exists and has one unbound type var
+ * Parser creates WildTypePattern namePatterns = {Foo}, typeParameters=WTP{E}
+ * resolveBindings requireExactType = true | false
+ * resolves typeParameters to ExactTypePattern(TVRT(E))
+ * resolves Foo to RT(Foo - raw)
+ * returns ExactTypePattern(<1:>LFoo; - generic) 1=E
+ *
+ * <E>... Foo<E> where Foo exists and is not generic (or has different bounds)
+ * Parser creates WildTypePattern namePatterns = {Foo}, typeParameters=WTP{E}
+ * resolveBindings resolves typeParameters to ExactTypePattern(TVRT(E))
+ * resolves Foo to RT(Foo)
+ * finds that Foo is not generic / type var mismatch
+ * requireExactType = true ->returns TypePattern.NO (and issues error)
+ * = false -> XLint then return ExactTypePattern(<1:>LFoo;)
+ *
+ * <E>... Foo<E extends Number> where Foo exists and bounds match
+ * Parser creates WildTypePattern namePatterns = {Foo}, typeParameters=WTP{E},uB=WTP{Number}
+ * resolveBindings resolves typeParameters to ExactTypePattern(TVRT(E extends Number))
+ * resolves Foo to RT(Foo)
+ * returns ExactTypePattern(<1:Ljava/lang/Number;>LFoo;) 1=E
+ *
+ * Foo<String> where Foo exists and String meets the bounds
+ * Parser creates WildTypePattern namePatterns = {Foo}, typeParameters=WTP{String}
+ * resolveBindings resolves typeParameters to ExactTypePattern(String)
+ * resolves Foo to RT(Foo)
+ * returns ExactTypePattern(PFoo<String>; - parameterized)
+ *
+ * Foo<Str*> where Foo exists and takes one bound
+ * Parser creates WildTypePattern namePatterns = {Foo}, typeParameters=WTP{Str*}
+ * resolveBindings resolves typeParameters to WTP{Str*}
+ * resolves Foo to RT(Foo)
+ * returns WildTypePattern(name = Foo, typeParameters = WTP{Str*} isGeneric=false)
+ *
+ * Fo*<String>
+ * Parser creates WildTypePattern namePatterns = {Fo*}, typeParameters=WTP{String}
+ * resolveBindings resolves typeParameters to ETP{String}
+ * returns WildTypePattern(name = Fo*, typeParameters = ETP{String} isGeneric=false)
+ *
+ * <E>... Fo*<E>
+ * Parser creates WildTypePattern namePatterns = {Fo*}, typeParameters=WTP{E}
+ * resolveBindings resolves typeParameters to ETP{TVRT(E)}
+ * returns WildTypePattern(name = Fo*, typeParameters = ETP{TVRT(E)} isGeneric=true)
+ *
+ * <E>... Fo*<E extends Number>
+ * Parser creates WildTypePattern namePatterns = {Fo*}, typeParameters=WTP{E,uB=WTP(Number)}
+ * resolveBindings resolves typeParameters to ETP{TVRT(E extends Number)}
+ * returns WildTypePattern(name = Fo*, typeParameters = ETP{TVRT(E extends Number)} isGeneric=true)
+ *
+ * <E>... Foo<E extends Number+> where Foo exists and takes one bound
+ * Parser creates WildTypePattern namePatterns = {Foo}, typeParameters=WTP{E,uB=WTP(Number+)}
+ * resolveBindings resolves typeParameters to WildTypeVariableReferencePattern{TVP(name="E",uB=Number+)}
+ * resolves Foo to RT(Foo)
+ * if requireExactType (but this doesn't allow + ? )
+ * if typeParameters.matches(RT(Foo - generic).getTypeVariables()
+ * return ETP(<1:Ljava/lang/Number;>LFoo;)
+ * else return TypePattern.NO and issue warning
+ * else
+ * if !typeParameters.matches(RT(Foo - generic).getTypeVariables()
+ * issue warning (XLint?)
+ * return WildTypePattern(name=Foo, typeParameters=WTVRP{TVP(E,Number+)} isGeneric=true
+ *
+ * <E>... Fo*<E extends Number+>
+ * Parser creates WildTypePattern namePatterns = {Fo*}, typeParameters=WTP{E,uB=WTP(Number+)}
+ * resolveBindings resolves typeParameters to WildTypeVariableReferencePattern{TVP(name="E",uB=Number+)}
+ * returns WildTypePattern(name=Fo*, typeParamters = WTVRP{TVP(name="E" ub=Number+)} isGeneric=true)
+ *
+ * TODO:
+ *
+ * <E>... Foo<E,String>
+ *
+ * <S,T>... Foo<S,T extends S>
+ *
+ * Foo<?>
+ *
+ * Foo<? extends Number>
+ *
+ * Foo<? extends Number+>
+ *
+ * Foo<? super Number>
+ *
+ */
public class WildTypePattern extends TypePattern {
private NamePattern[] namePatterns;
int ellipsisCount;
@@ -168,10 +264,25 @@ public class WildTypePattern extends TypePattern {
annotationPattern.resolve(type.getWorld());
return matchesExactlyByName(targetTypeName) &&
+ // matchesParameters(type) &&
annotationPattern.matches(annotatedType).alwaysTrue();
}
+ // we've matched against the base (or raw) type, but if this type pattern specifies parameters or
+ // type variables we need to make sure we match against them too
+ private boolean matchesParameters(ResolvedType aType) {
+ if (isGeneric) {
+ if (!aType.isGenericType()) return false;
+ // we have to match type variables
+
+ } else if (typeParameters.size() > 0) {
+ if(!aType.isParameterizedType()) return false;
+ // we have to match type parameters
+ }
+ return true;
+ }
+
/**
* Used in conjunction with checks on 'isStar()' to tell you if this pattern represents '*' or '*[]' which are
* different !
@@ -479,7 +590,7 @@ public class WildTypePattern extends TypePattern {
// use a special variant of Any TypePattern called
// AnyWithAnnotation
if (annotationPattern == AnnotationTypePattern.ANY) {
- if (dim == 0 && !isVarArgs) { // pr72531
+ if (dim == 0 && !isVarArgs && upperBound == null && lowerBound == null && (additionalInterfaceBounds == null || additionalInterfaceBounds.length==0)) { // pr72531
return TypePattern.ANY; //??? loses source location
}
} else {
@@ -889,6 +1000,18 @@ public class WildTypePattern extends TypePattern {
FileUtil.writeStringArray(importedPrefixes, s);
writeLocation(s);
annotationPattern.write(s);
+ // generics info, new in M3
+ s.writeBoolean(isGeneric);
+ s.writeBoolean(upperBound != null);
+ if (upperBound != null) upperBound.write(s);
+ s.writeBoolean(lowerBound != null);
+ if (lowerBound != null) lowerBound.write(s);
+ s.writeInt(additionalInterfaceBounds == null ? 0 : additionalInterfaceBounds.length);
+ if (additionalInterfaceBounds != null) {
+ for (int i = 0; i < additionalInterfaceBounds.length; i++) {
+ additionalInterfaceBounds[i].write(s);
+ }
+ }
}
public static TypePattern read(VersionedDataInputStream s, ISourceContext context) throws IOException {
@@ -918,6 +1041,21 @@ public class WildTypePattern extends TypePattern {
ret.importedPrefixes = FileUtil.readStringArray(s);
ret.readLocation(context, s);
ret.setAnnotationTypePattern(AnnotationTypePattern.read(s,context));
+ // generics info, new in M3
+ ret.isGeneric = s.readBoolean();
+ if (s.readBoolean()) {
+ ret.upperBound = TypePattern.read(s,context);
+ }
+ if (s.readBoolean()) {
+ ret.lowerBound = TypePattern.read(s,context);
+ }
+ int numIfBounds = s.readInt();
+ if (numIfBounds > 0) {
+ ret.additionalInterfaceBounds = new TypePattern[numIfBounds];
+ for (int i = 0; i < numIfBounds; i++) {
+ ret.additionalInterfaceBounds[i] = TypePattern.read(s,context);
+ }
+ }
return ret;
}
diff --git a/weaver/testdata/AfterReturningFancyHelloWorld.txt b/weaver/testdata/AfterReturningFancyHelloWorld.txt
index 1bcdad132..f2447b509 100644
--- a/weaver/testdata/AfterReturningFancyHelloWorld.txt
+++ b/weaver/testdata/AfterReturningFancyHelloWorld.txt
@@ -98,4 +98,5 @@ public abstract class FancyHelloWorld extends java.lang.Object:
| ARETURN
method-execution(java.lang.String FancyHelloWorld.getName())
end public static String getName()
+
end public abstract class FancyHelloWorld
diff --git a/weaver/testdata/AfterReturningHelloWorld.txt b/weaver/testdata/AfterReturningHelloWorld.txt
index 271a34b38..6f58d2f3d 100644
--- a/weaver/testdata/AfterReturningHelloWorld.txt
+++ b/weaver/testdata/AfterReturningHelloWorld.txt
@@ -27,4 +27,5 @@ public class HelloWorld extends java.lang.Object:
| RETURN
method-execution(void HelloWorld.main(java.lang.String[]))
end public static void main(String[])
+
end public class HelloWorld
diff --git a/weaver/testdata/BeforeFancyHelloWorld.txt b/weaver/testdata/BeforeFancyHelloWorld.txt
index 18136b693..bc2ef49ba 100644
--- a/weaver/testdata/BeforeFancyHelloWorld.txt
+++ b/weaver/testdata/BeforeFancyHelloWorld.txt
@@ -87,4 +87,5 @@ public abstract class FancyHelloWorld extends java.lang.Object:
| ARETURN
method-execution(java.lang.String FancyHelloWorld.getName())
end public static String getName()
+
end public abstract class FancyHelloWorld
diff --git a/weaver/testdata/BeforeHelloWorld.txt b/weaver/testdata/BeforeHelloWorld.txt
index 3fc3fa818..d89b5acd9 100644
--- a/weaver/testdata/BeforeHelloWorld.txt
+++ b/weaver/testdata/BeforeHelloWorld.txt
@@ -23,4 +23,5 @@ public class HelloWorld extends java.lang.Object:
| RETURN (line 11)
method-execution(void HelloWorld.main(java.lang.String[]))
end public static void main(String[])
+
end public class HelloWorld
diff --git a/weaver/testdata/dummyAspect.jar b/weaver/testdata/dummyAspect.jar
index 8095fddf4..bc1212450 100644
--- a/weaver/testdata/dummyAspect.jar
+++ b/weaver/testdata/dummyAspect.jar
Binary files differ
diff --git a/weaver/testdata/ltw-acaspects.jar b/weaver/testdata/ltw-acaspects.jar
index ed55e51bc..27c112671 100644
--- a/weaver/testdata/ltw-acaspects.jar
+++ b/weaver/testdata/ltw-acaspects.jar
Binary files differ
diff --git a/weaver/testdata/ltw-aspects.jar b/weaver/testdata/ltw-aspects.jar
index 2e1e86fb1..436e5a225 100644
--- a/weaver/testdata/ltw-aspects.jar
+++ b/weaver/testdata/ltw-aspects.jar
Binary files differ
diff --git a/weaver/testdata/ltw-classes.jar b/weaver/testdata/ltw-classes.jar
index 014510d57..b79e963fc 100644
--- a/weaver/testdata/ltw-classes.jar
+++ b/weaver/testdata/ltw-classes.jar
Binary files differ
diff --git a/weaver/testdata/ltw-deaspects.jar b/weaver/testdata/ltw-deaspects.jar
index 853e7147b..6dd510a5a 100644
--- a/weaver/testdata/ltw-deaspects.jar
+++ b/weaver/testdata/ltw-deaspects.jar
Binary files differ
diff --git a/weaver/testdata/ltw-dwaspects.jar b/weaver/testdata/ltw-dwaspects.jar
index 7ca214cf3..5e9d88bd8 100644
--- a/weaver/testdata/ltw-dwaspects.jar
+++ b/weaver/testdata/ltw-dwaspects.jar
Binary files differ
diff --git a/weaver/testdata/ltw-itdaspects.jar b/weaver/testdata/ltw-itdaspects.jar
index 6144a3f6f..cf998df73 100644
--- a/weaver/testdata/ltw-itdaspects.jar
+++ b/weaver/testdata/ltw-itdaspects.jar
Binary files differ
diff --git a/weaver/testdata/ltw-peraspects.jar b/weaver/testdata/ltw-peraspects.jar
index 2c37baeb7..25ad702c7 100644
--- a/weaver/testdata/ltw-peraspects.jar
+++ b/weaver/testdata/ltw-peraspects.jar
Binary files differ
diff --git a/weaver/testdata/ltw-woven.jar b/weaver/testdata/ltw-woven.jar
index d4f117eea..6db485722 100644
--- a/weaver/testdata/ltw-woven.jar
+++ b/weaver/testdata/ltw-woven.jar
Binary files differ
diff --git a/weaver/testdata/megatrace.jar b/weaver/testdata/megatrace.jar
index 8735641c5..39c09bf90 100644
--- a/weaver/testdata/megatrace.jar
+++ b/weaver/testdata/megatrace.jar
Binary files differ
diff --git a/weaver/testdata/megatrace0easy.jar b/weaver/testdata/megatrace0easy.jar
index 11deb555c..7f39269ca 100644
--- a/weaver/testdata/megatrace0easy.jar
+++ b/weaver/testdata/megatrace0easy.jar
Binary files differ
diff --git a/weaver/testdata/megatrace0hard.jar b/weaver/testdata/megatrace0hard.jar
index 84f4a7b1e..cac0d6b18 100644
--- a/weaver/testdata/megatrace0hard.jar
+++ b/weaver/testdata/megatrace0hard.jar
Binary files differ
diff --git a/weaver/testdata/megatraceNoweave.jar b/weaver/testdata/megatraceNoweave.jar
index 4f8d26a4a..6ee827fc1 100644
--- a/weaver/testdata/megatraceNoweave.jar
+++ b/weaver/testdata/megatraceNoweave.jar
Binary files differ
diff --git a/weaver/testdata/tracing.jar b/weaver/testdata/tracing.jar
index 1a50581b1..ebd414b1c 100644
--- a/weaver/testdata/tracing.jar
+++ b/weaver/testdata/tracing.jar
Binary files differ