aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--aspectj5rt/java5-src/org/aspectj/internal/lang/reflect/AdviceImpl.java2
-rw-r--r--aspectj5rt/java5-src/org/aspectj/internal/lang/reflect/AjTypeImpl.java5
-rw-r--r--aspectj5rt/java5-src/org/aspectj/lang/reflect/AjTypeSystem.java2
-rw-r--r--aspectj5rt/java5-testsrc/org/aspectj/internal/lang/reflect/AjTypeTests.java2
-rw-r--r--aspectj5rt/java5-testsrc/org/aspectj/internal/lang/reflect/AjTypeTestsWithAspects.java12
5 files changed, 12 insertions, 11 deletions
diff --git a/aspectj5rt/java5-src/org/aspectj/internal/lang/reflect/AdviceImpl.java b/aspectj5rt/java5-src/org/aspectj/internal/lang/reflect/AdviceImpl.java
index 0cdf0bc96..77b30223f 100644
--- a/aspectj5rt/java5-src/org/aspectj/internal/lang/reflect/AdviceImpl.java
+++ b/aspectj5rt/java5-src/org/aspectj/internal/lang/reflect/AdviceImpl.java
@@ -64,7 +64,7 @@ public class AdviceImpl implements Advice {
this.genericParameterTypes = new Type[genTypes.length - syntheticCount];
for (int i = 0; i < genericParameterTypes.length; i++) {
if (genTypes[i] instanceof Class) {
- this.genericParameterTypes[i] = AjTypeSystem.getAjType((Class)genTypes[i]);
+ this.genericParameterTypes[i] = AjTypeSystem.getAjType((Class<?>)genTypes[i]);
} else {
this.genericParameterTypes[i] = genTypes[i];
}
diff --git a/aspectj5rt/java5-src/org/aspectj/internal/lang/reflect/AjTypeImpl.java b/aspectj5rt/java5-src/org/aspectj/internal/lang/reflect/AjTypeImpl.java
index 60db9a2ba..8534d0743 100644
--- a/aspectj5rt/java5-src/org/aspectj/internal/lang/reflect/AjTypeImpl.java
+++ b/aspectj5rt/java5-src/org/aspectj/internal/lang/reflect/AjTypeImpl.java
@@ -118,8 +118,9 @@ public class AjTypeImpl<T> implements AjType<T> {
/* (non-Javadoc)
* @see org.aspectj.lang.reflect.AjType#getSupertype()
*/
- public AjType<?> getSupertype() {
- return new AjTypeImpl(clazz.getSuperclass());
+ public AjType<? super T> getSupertype() {
+ Class<? super T> superclass = clazz.getSuperclass();
+ return (AjType<? super T>) new AjTypeImpl(superclass);
}
/* (non-Javadoc)
diff --git a/aspectj5rt/java5-src/org/aspectj/lang/reflect/AjTypeSystem.java b/aspectj5rt/java5-src/org/aspectj/lang/reflect/AjTypeSystem.java
index fbd9a6644..737abc1b6 100644
--- a/aspectj5rt/java5-src/org/aspectj/lang/reflect/AjTypeSystem.java
+++ b/aspectj5rt/java5-src/org/aspectj/lang/reflect/AjTypeSystem.java
@@ -35,7 +35,7 @@ public class AjTypeSystem {
*/
public static <T> AjType<T> getAjType(Class<T> fromClass) {
if (ajTypes.containsKey(fromClass)) {
- WeakReference<AjType> weakRefToAjType = ajTypes.get(fromClass);
+ WeakReference<AjType<T>> weakRefToAjType = (WeakReference<AjType<T>>) ajTypes.get(fromClass);
AjType<T> theAjType = weakRefToAjType.get();
if (theAjType != null) {
return theAjType;
diff --git a/aspectj5rt/java5-testsrc/org/aspectj/internal/lang/reflect/AjTypeTests.java b/aspectj5rt/java5-testsrc/org/aspectj/internal/lang/reflect/AjTypeTests.java
index 211da98c3..f634d6c73 100644
--- a/aspectj5rt/java5-testsrc/org/aspectj/internal/lang/reflect/AjTypeTests.java
+++ b/aspectj5rt/java5-testsrc/org/aspectj/internal/lang/reflect/AjTypeTests.java
@@ -60,7 +60,7 @@ public class AjTypeTests extends TestCase {
}
public void testGetSupertype() {
- Class stringSuper = String.class.getSuperclass();
+ Class<?> stringSuper = String.class.getSuperclass();
AjType ajSuper = stringType.getSupertype();
assertEquals(AjTypeSystem.getAjType(stringSuper),ajSuper);
}
diff --git a/aspectj5rt/java5-testsrc/org/aspectj/internal/lang/reflect/AjTypeTestsWithAspects.java b/aspectj5rt/java5-testsrc/org/aspectj/internal/lang/reflect/AjTypeTestsWithAspects.java
index 7b15d3e64..046733b82 100644
--- a/aspectj5rt/java5-testsrc/org/aspectj/internal/lang/reflect/AjTypeTestsWithAspects.java
+++ b/aspectj5rt/java5-testsrc/org/aspectj/internal/lang/reflect/AjTypeTestsWithAspects.java
@@ -42,7 +42,7 @@ import org.aspectj.lang.reflect.TypePatternBasedPerClause;
public class AjTypeTestsWithAspects extends TestCase {
- private AjType sa;
+ private AjType<SimpleAspect> sa;
protected void setUp() throws Exception {
super.setUp();
@@ -50,11 +50,11 @@ public class AjTypeTestsWithAspects extends TestCase {
}
public void testGetPerClause() {
- AjType perThisA = AjTypeSystem.getAjType(PerThisAspect.class);
- AjType perTargetA = AjTypeSystem.getAjType(PerTargetAspect.class);
- AjType perCflowA = AjTypeSystem.getAjType(PerCflowAspect.class);
- AjType perCflowbelowA = AjTypeSystem.getAjType(PerCflowbelowAspect.class);
- AjType perTypeWithinA = AjTypeSystem.getAjType(PerTypeWithin.class);
+ AjType<PerThisAspect> perThisA = AjTypeSystem.getAjType(PerThisAspect.class);
+ AjType<PerTargetAspect> perTargetA = AjTypeSystem.getAjType(PerTargetAspect.class);
+ AjType<PerCflowAspect> perCflowA = AjTypeSystem.getAjType(PerCflowAspect.class);
+ AjType<PerCflowbelowAspect> perCflowbelowA = AjTypeSystem.getAjType(PerCflowbelowAspect.class);
+ AjType<PerTypeWithin> perTypeWithinA = AjTypeSystem.getAjType(PerTypeWithin.class);
PerClause pc = perThisA.getPerClause();
assertEquals(PerClauseKind.PERTHIS,pc.getKind());