diff options
author | aclement <aclement> | 2007-11-07 09:56:35 +0000 |
---|---|---|
committer | aclement <aclement> | 2007-11-07 09:56:35 +0000 |
commit | 2966d25ce98ad492d5fb61b5262132e95e06da9b (patch) | |
tree | a196d7a83167f108c83c103d732999f84a1be40c /org.aspectj.ajdt.core/src | |
parent | ef9eee2a1870d8b7208ea4ce186e293cc70c690d (diff) | |
download | aspectj-2966d25ce98ad492d5fb61b5262132e95e06da9b.tar.gz aspectj-2966d25ce98ad492d5fb61b5262132e95e06da9b.zip |
pr169428: text and fix for checking decp annotation specified on construct inside an aspect type
Diffstat (limited to 'org.aspectj.ajdt.core/src')
-rw-r--r-- | org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/ast/ValidateAtAspectJAnnotationsVisitor.java | 18 |
1 files changed, 16 insertions, 2 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 09d6b441e..bda45f1d7 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 @@ -26,6 +26,7 @@ import org.aspectj.org.eclipse.jdt.internal.compiler.ASTVisitor; import org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation; import org.aspectj.org.eclipse.jdt.internal.compiler.ast.Argument; import org.aspectj.org.eclipse.jdt.internal.compiler.ast.CompilationUnitDeclaration; +import org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldDeclaration; import org.aspectj.org.eclipse.jdt.internal.compiler.ast.MemberValuePair; import org.aspectj.org.eclipse.jdt.internal.compiler.ast.MethodDeclaration; import org.aspectj.org.eclipse.jdt.internal.compiler.ast.NormalAnnotation; @@ -37,6 +38,7 @@ import org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference; import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.BlockScope; import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.ClassScope; import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.CompilationUnitScope; +import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.MethodScope; import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.SourceTypeBinding; import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.TypeBinding; import org.aspectj.weaver.AdviceKind; @@ -60,6 +62,7 @@ public class ValidateAtAspectJAnnotationsVisitor extends ASTVisitor { private static final char[] aroundAdviceSig = "Lorg/aspectj/lang/annotation/Around;".toCharArray(); private static final char[] pointcutSig = "Lorg/aspectj/lang/annotation/Pointcut;".toCharArray(); private static final char[] aspectSig = "Lorg/aspectj/lang/annotation/Aspect;".toCharArray(); + private static final char[] declareParentsSig = "Lorg/aspectj/lang/annotation/DeclareParents;".toCharArray(); private static final char[] adviceNameSig = "Lorg/aspectj/lang/annotation/AdviceName;".toCharArray(); private static final char[] orgAspectJLangAnnotation = "org/aspectj/lang/annotation/".toCharArray(); private static final char[] voidType = "void".toCharArray(); @@ -145,7 +148,16 @@ public class ValidateAtAspectJAnnotationsVisitor extends ASTVisitor { } CompilationAndWeavingContext.leavingPhase(tok); } - + + public boolean visit(FieldDeclaration fieldDeclaration, MethodScope scope) { + ajAnnotations = new AspectJAnnotations(fieldDeclaration.annotations); + if (ajAnnotations.hasDeclareParents && !insideAspect()) { + scope.problemReporter().signalError(fieldDeclaration.sourceStart, + fieldDeclaration.sourceEnd, + "DeclareParents can only be used inside an aspect type"); + } + return true; + } public boolean visit(MethodDeclaration methodDeclaration, ClassScope scope) { if (methodDeclaration.hasErrors()) { return false; @@ -632,7 +644,7 @@ public class ValidateAtAspectJAnnotationsVisitor extends ASTVisitor { boolean hasPointcutAnnotation = false; boolean hasAspectAnnotation = false; boolean hasAdviceNameAnnotation = false; - + boolean hasDeclareParents = false; boolean hasMultipleAdviceAnnotations = false; boolean hasMultiplePointcutAnnotations = false; boolean hasMultipleAspectAnnotations = false; @@ -670,6 +682,8 @@ public class ValidateAtAspectJAnnotationsVisitor extends ASTVisitor { } else if (CharOperation.equals(adviceNameSig,sig)) { hasAdviceNameAnnotation = true; adviceNameAnnotation = annotations[i]; + } else if (CharOperation.equals(declareParentsSig,sig)) { + hasDeclareParents = true; } else if (CharOperation.equals(aspectSig,sig)) { if (hasAspectAnnotation) { hasMultipleAspectAnnotations = true; |