summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/ValidateAtAspectJAnnotationsVisitor.java3
-rw-r--r--tests/bugs151/pr121616.java16
-rw-r--r--tests/src/org/aspectj/systemtest/ajc151/Ajc151Tests.java4
-rw-r--r--tests/src/org/aspectj/systemtest/ajc151/ajc151.xml6
4 files changed, 29 insertions, 0 deletions
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/ValidateAtAspectJAnnotationsVisitor.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/ValidateAtAspectJAnnotationsVisitor.java
index e16e73d51..313411f7b 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/ValidateAtAspectJAnnotationsVisitor.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/ValidateAtAspectJAnnotationsVisitor.java
@@ -147,6 +147,9 @@ public class ValidateAtAspectJAnnotationsVisitor extends ASTVisitor {
}
public boolean visit(MethodDeclaration methodDeclaration, ClassScope scope) {
+ if (methodDeclaration.hasErrors()) {
+ return false;
+ }
ContextToken tok = CompilationAndWeavingContext.enteringPhase(CompilationAndWeavingContext.VALIDATING_AT_ASPECTJ_ANNOTATIONS, methodDeclaration.selector);
ajAnnotations = new AspectJAnnotations(methodDeclaration.annotations);
if (!methodDeclaration.getClass().equals(AjMethodDeclaration.class)) {
diff --git a/tests/bugs151/pr121616.java b/tests/bugs151/pr121616.java
new file mode 100644
index 000000000..656260112
--- /dev/null
+++ b/tests/bugs151/pr121616.java
@@ -0,0 +1,16 @@
+import org.aspectj.lang.annotation.Aspect;
+import org.aspectj.lang.annotation.Before;
+
+class Main {
+ public static void main(String[] args) {
+ System.out.println("Main");
+ }
+}
+
+@Aspect
+class MainLogger {
+ @Before("execution(* main(..))")
+ public void log(JoinPoint thisJoinPoint) {
+ System.out.println("Before " + thisJoinPoint);
+ }
+}
diff --git a/tests/src/org/aspectj/systemtest/ajc151/Ajc151Tests.java b/tests/src/org/aspectj/systemtest/ajc151/Ajc151Tests.java
index 7a64444b9..24b006fd2 100644
--- a/tests/src/org/aspectj/systemtest/ajc151/Ajc151Tests.java
+++ b/tests/src/org/aspectj/systemtest/ajc151/Ajc151Tests.java
@@ -160,6 +160,10 @@ public class Ajc151Tests extends org.aspectj.testing.XMLBasedAjcTestCase {
runTest("@AJ no NPE with deow when structure model isn't generated");
}
+ public void testAtAspectWithoutJoinPointImport_pr121616() {
+ runTest("@AJ without JoinPoint import");
+ }
+
/*
* Load-time weaving bugs and enhancements
*/
diff --git a/tests/src/org/aspectj/systemtest/ajc151/ajc151.xml b/tests/src/org/aspectj/systemtest/ajc151/ajc151.xml
index de0488dbd..46e8bc97d 100644
--- a/tests/src/org/aspectj/systemtest/ajc151/ajc151.xml
+++ b/tests/src/org/aspectj/systemtest/ajc151/ajc151.xml
@@ -176,6 +176,12 @@
</compile>
</ajc-test>
+ <ajc-test dir="bugs151" title="@AJ without JoinPoint import">
+ <compile files="pr121616.java" options="-1.5">
+ <message kind="error" line="13" text="JoinPoint cannot be resolved to a type"/>
+ </compile>
+ </ajc-test>
+
<!-- New features down here... when they arent big enough to have their own test file -->
<ajc-test dir="features151/ptw" title="exposing withintype">