aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/lookup/AjLookupEnvironment.java9
-rw-r--r--tests/ajcTests.xml7
-rw-r--r--tests/ajcTestsFailing.xml8
-rw-r--r--tests/jimTests.xml3
4 files changed, 17 insertions, 10 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++) {
diff --git a/tests/ajcTests.xml b/tests/ajcTests.xml
index 1e192ba8a..5f477a19b 100644
--- a/tests/ajcTests.xml
+++ b/tests/ajcTests.xml
@@ -5711,4 +5711,11 @@
<message kind="error" line="6"/>
</compile>
</ajc-test>
+
+ <ajc-test dir="errors" keywords="error"
+ title="class extending abstract aspect">
+ <compile files="ClassExtendingAbstractAspectCE.java">
+ <message kind="error" line="20"/>
+ </compile>
+ </ajc-test>
</suite>
diff --git a/tests/ajcTestsFailing.xml b/tests/ajcTestsFailing.xml
index 578f0aa75..30dfe9160 100644
--- a/tests/ajcTestsFailing.xml
+++ b/tests/ajcTestsFailing.xml
@@ -11,13 +11,6 @@
</compile>
</ajc-test>
- <ajc-test dir="errors" keywords="error"
- title="class extending abstract aspect">
- <compile files="ClassExtendingAbstractAspectCE.java">
- <message kind="error" line="20"/>
- </compile>
- </ajc-test>
-
<ajc-test dir="incremental/stringliteral"
title="incrementally change string size and wire in injar classes">
<compile staging="true" options="-incremental"
@@ -43,6 +36,7 @@
before main packageOne.Main"/>
</ajc-test>
+ <!-- The correct behavior of this case needs to be thought through -->
<ajc-test dir="bugs" pr="34206"
title="before():execution(new(..)) does not throw NoAspectBoundException">
<compile files="AspectInitError.java"/>
diff --git a/tests/jimTests.xml b/tests/jimTests.xml
index f4adb0f97..7c1c4af1f 100644
--- a/tests/jimTests.xml
+++ b/tests/jimTests.xml
@@ -1,9 +1,6 @@
<!DOCTYPE suite SYSTEM "../tests/ajcTestSuite.dtd">
<suite>
-
-
-
<!--
<ajc-test dir="new" pr="885"