diff options
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"> |