aboutsummaryrefslogtreecommitdiffstats
path: root/org.aspectj.ajdt.core
diff options
context:
space:
mode:
authorjhugunin <jhugunin>2003-03-12 23:37:01 +0000
committerjhugunin <jhugunin>2003-03-12 23:37:01 +0000
commit03448a7d4363abe6cd99da99a050fecef9cf8f72 (patch)
tree11e966fadcf97f0814ddf95b0d7fe4d9ba109353 /org.aspectj.ajdt.core
parentd5731957188b6280e850cf2bbc238469244b6d86 (diff)
downloadaspectj-03448a7d4363abe6cd99da99a050fecef9cf8f72.tar.gz
aspectj-03448a7d4363abe6cd99da99a050fecef9cf8f72.zip
fix for class not allowed to extend aspect and moving corresponding test out of failing
Diffstat (limited to 'org.aspectj.ajdt.core')
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/AjLookupEnvironment.java9
1 files changed, 9 insertions, 0 deletions
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/AjLookupEnvironment.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/AjLookupEnvironment.java
index 522b80197..797ae15c3 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/AjLookupEnvironment.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/AjLookupEnvironment.java
@@ -122,6 +122,15 @@ public class AjLookupEnvironment extends LookupEnvironment {
}
SourceTypeBinding sourceType = s.referenceContext.binding;
+ // test classes don't extend aspects
+ if (sourceType.superclass != null) {
+ ResolvedTypeX parent = factory.fromEclipse(sourceType.superclass);
+ if (parent.isAspect() && !(dec instanceof AspectDeclaration)) {
+ factory.showMessage(IMessage.ERROR, "class \'" + new String(sourceType.sourceName) +
+ "\' can not extend aspect \'" + parent.getName() + "\'",
+ factory.fromEclipse(sourceType).getSourceLocation(), null);
+ }
+ }
ReferenceBinding[] memberTypes = sourceType.memberTypes;
for (int i = 0, length = memberTypes.length; i < length; i++) {