diff options
author | jhugunin <jhugunin> | 2003-03-12 23:37:01 +0000 |
---|---|---|
committer | jhugunin <jhugunin> | 2003-03-12 23:37:01 +0000 |
commit | 03448a7d4363abe6cd99da99a050fecef9cf8f72 (patch) | |
tree | 11e966fadcf97f0814ddf95b0d7fe4d9ba109353 /org.aspectj.ajdt.core | |
parent | d5731957188b6280e850cf2bbc238469244b6d86 (diff) | |
download | aspectj-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.java | 9 |
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++) { |