diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/lombok/eclipse/EclipseAST.java | 36 | ||||
-rw-r--r-- | src/lombok/eclipse/EclipseASTAdapter.java | 5 | ||||
-rw-r--r-- | src/lombok/eclipse/EclipseASTVisitor.java | 50 | ||||
-rw-r--r-- | src/lombok/eclipse/TransformEclipseAST.java | 29 |
4 files changed, 83 insertions, 37 deletions
diff --git a/src/lombok/eclipse/EclipseAST.java b/src/lombok/eclipse/EclipseAST.java index 5450a9a9..9fed839c 100644 --- a/src/lombok/eclipse/EclipseAST.java +++ b/src/lombok/eclipse/EclipseAST.java @@ -17,6 +17,7 @@ import org.eclipse.jdt.internal.compiler.CompilationResult; import org.eclipse.jdt.internal.compiler.apt.dispatch.AptProblem; import org.eclipse.jdt.internal.compiler.ast.ASTNode; import org.eclipse.jdt.internal.compiler.ast.AbstractMethodDeclaration; +import org.eclipse.jdt.internal.compiler.ast.Annotation; import org.eclipse.jdt.internal.compiler.ast.Argument; import org.eclipse.jdt.internal.compiler.ast.Clinit; import org.eclipse.jdt.internal.compiler.ast.CompilationUnitDeclaration; @@ -60,6 +61,16 @@ public class EclipseAST { visitor.visitLocal(child, (LocalDeclaration)n); traverseChildren(visitor, child); visitor.endVisitLocal(child, (LocalDeclaration)n); + } else if ( n instanceof Annotation ) { + Node parent = child.up(); + if ( parent.node instanceof TypeDeclaration ) + visitor.visitAnnotationOnType(parent, (TypeDeclaration)parent.node, (Annotation)n); + else if ( parent.node instanceof AbstractMethodDeclaration ) + visitor.visitAnnotationOnMethod(parent, (AbstractMethodDeclaration)parent.node, (Annotation)n); + else if ( parent.node instanceof FieldDeclaration ) + visitor.visitAnnotationOnField(parent, (FieldDeclaration)parent.node, (Annotation)n); + else if ( parent.node instanceof LocalDeclaration ) + visitor.visitAnnotationOnLocal(parent, (LocalDeclaration)parent.node, (Annotation)n); } else if ( n instanceof Statement ) { visitor.visitStatement(child, (Statement)n); traverseChildren(visitor, child); @@ -302,6 +313,7 @@ public class EclipseAST { childNodes.addAll(buildTree(type.fields)); childNodes.addAll(buildTree(type.memberTypes)); childNodes.addAll(buildTree(type.methods)); + childNodes.addAll(buildTree(type.annotations)); return putInMap(new Node(type, childNodes)); } @@ -320,7 +332,10 @@ public class EclipseAST { private Node buildTree(FieldDeclaration field) { if ( field instanceof Initializer ) return buildTree((Initializer)field); if ( identityDetector.containsKey(field) ) return null; - return putInMap(new Node(field, singleton(buildWithStatement(field.initialization)))); + List<Node> childNodes = new ArrayList<Node>(); + addIfNotNull(childNodes, buildWithStatement(field.initialization)); + childNodes.addAll(buildTree(field.annotations)); + return putInMap(new Node(field, childNodes)); } private Node buildTree(Initializer initializer) { @@ -340,6 +355,7 @@ public class EclipseAST { List<Node> childNodes = new ArrayList<Node>(); childNodes.addAll(buildTree(method.arguments)); childNodes.addAll(buildTree(method.statements)); + childNodes.addAll(buildTree(method.annotations)); return putInMap(new Node(method, childNodes)); } @@ -355,7 +371,20 @@ public class EclipseAST { private Node buildTree(LocalDeclaration local) { if ( identityDetector.containsKey(local) ) return null; - return putInMap(new Node(local, singleton(buildWithStatement(local.initialization)))); + List<Node> childNodes = new ArrayList<Node>(); + addIfNotNull(childNodes, buildWithStatement(local.initialization)); + childNodes.addAll(buildTree(local.annotations)); + return putInMap(new Node(local, childNodes)); + } + + private Collection<Node> buildTree(Annotation[] annotations) { + if ( annotations == null ) return Collections.emptyList(); + List<Node> elements = new ArrayList<Node>(); + for ( Annotation an : annotations ) { + if ( an == null ) continue; + elements.add(putInMap(new Node(an, null))); + } + return elements; } private Collection<Node> buildTree(Statement[] children) { @@ -375,13 +404,14 @@ public class EclipseAST { //We drill down because LocalDeclarations and TypeDeclarations can occur anywhere, even in, say, //an if block, or even the expression on an assert statement! + identityDetector.put(child, null); return drill(child); } private Node drill(Statement statement) { List<Node> childNodes = new ArrayList<Node>(); for ( FieldAccess fa : fieldsOf(statement.getClass()) ) childNodes.addAll(buildWithField(statement, fa)); - return new Node(statement, childNodes); + return putInMap(new Node(statement, childNodes)); } private static class FieldAccess { diff --git a/src/lombok/eclipse/EclipseASTAdapter.java b/src/lombok/eclipse/EclipseASTAdapter.java index 50fded89..d2e0050e 100644 --- a/src/lombok/eclipse/EclipseASTAdapter.java +++ b/src/lombok/eclipse/EclipseASTAdapter.java @@ -3,6 +3,7 @@ package lombok.eclipse; import lombok.eclipse.EclipseAST.Node; import org.eclipse.jdt.internal.compiler.ast.AbstractMethodDeclaration; +import org.eclipse.jdt.internal.compiler.ast.Annotation; import org.eclipse.jdt.internal.compiler.ast.CompilationUnitDeclaration; import org.eclipse.jdt.internal.compiler.ast.FieldDeclaration; import org.eclipse.jdt.internal.compiler.ast.Initializer; @@ -14,14 +15,18 @@ public abstract class EclipseASTAdapter implements EclipseASTVisitor { @Override public void visitCompilationUnit(Node node, CompilationUnitDeclaration unit) {} @Override public void endVisitCompilationUnit(Node node, CompilationUnitDeclaration unit) {} @Override public void visitType(Node node, TypeDeclaration type) {} + @Override public void visitAnnotationOnType(Node node, TypeDeclaration type, Annotation annotation) {} @Override public void endVisitType(Node node, TypeDeclaration type) {} @Override public void visitInitializer(Node node, Initializer initializer) {} @Override public void endVisitInitializer(Node node, Initializer initializer) {} @Override public void visitField(Node node, FieldDeclaration field) {} + @Override public void visitAnnotationOnField(Node node, FieldDeclaration Field, Annotation annotation) {} @Override public void endVisitField(Node node, FieldDeclaration field) {} @Override public void visitMethod(Node node, AbstractMethodDeclaration method) {} + @Override public void visitAnnotationOnMethod(Node node, AbstractMethodDeclaration method, Annotation annotation) {} @Override public void endVisitMethod(Node node, AbstractMethodDeclaration method) {} @Override public void visitLocal(Node node, LocalDeclaration local) {} + @Override public void visitAnnotationOnLocal(Node node, LocalDeclaration local, Annotation annotation) {} @Override public void endVisitLocal(Node node, LocalDeclaration local) {} @Override public void visitStatement(Node node, Statement statement) {} @Override public void endVisitStatement(Node node, Statement statement) {} diff --git a/src/lombok/eclipse/EclipseASTVisitor.java b/src/lombok/eclipse/EclipseASTVisitor.java index ac4d0e33..a9b4e706 100644 --- a/src/lombok/eclipse/EclipseASTVisitor.java +++ b/src/lombok/eclipse/EclipseASTVisitor.java @@ -5,6 +5,7 @@ import java.lang.reflect.Modifier; import lombok.eclipse.EclipseAST.Node; import org.eclipse.jdt.internal.compiler.ast.AbstractMethodDeclaration; +import org.eclipse.jdt.internal.compiler.ast.Annotation; import org.eclipse.jdt.internal.compiler.ast.Argument; import org.eclipse.jdt.internal.compiler.ast.Block; import org.eclipse.jdt.internal.compiler.ast.CompilationUnitDeclaration; @@ -16,18 +17,20 @@ import org.eclipse.jdt.internal.compiler.ast.Statement; import org.eclipse.jdt.internal.compiler.ast.TypeDeclaration; import org.eclipse.jdt.internal.compiler.ast.TypeReference; +//TODO public interface EclipseASTVisitor { /** * Called at the very beginning and end. */ - void visitCompilationUnit(Node node, CompilationUnitDeclaration unit); - void endVisitCompilationUnit(Node node, CompilationUnitDeclaration unit); + void visitCompilationUnit(Node top, CompilationUnitDeclaration unit); + void endVisitCompilationUnit(Node top, CompilationUnitDeclaration unit); /** * Called when visiting a type (a class, interface, annotation, enum, etcetera). */ - void visitType(Node node, TypeDeclaration type); - void endVisitType(Node node, TypeDeclaration type); + void visitType(Node typeNode, TypeDeclaration type); + void visitAnnotationOnType(Node typeNode, TypeDeclaration type, Annotation annotation); + void endVisitType(Node typeNode, TypeDeclaration type); /** * Called when visiting a field of a class. @@ -35,39 +38,42 @@ public interface EclipseASTVisitor { * which are a subclass of FieldDeclaration, those do NOT result in a call to this method. They result * in a call to the visitInitializer method. */ - void visitField(Node node, FieldDeclaration field); - void endVisitField(Node node, FieldDeclaration field); + void visitField(Node fieldNode, FieldDeclaration field); + void visitAnnotationOnField(Node fieldNode, FieldDeclaration Field, Annotation annotation); + void endVisitField(Node fieldNode, FieldDeclaration field); /** * Called for static and instance initializers. You can tell the difference via the modifier flag on the * ASTNode (8 for static, 0 for not static). The content is in the 'block', not in the 'initialization', * which would always be null for an initializer instance. */ - void visitInitializer(Node node, Initializer initializer); - void endVisitInitializer(Node node, Initializer initializer); + void visitInitializer(Node initializerNode, Initializer initializer); + void endVisitInitializer(Node initializerNode, Initializer initializer); /** * Called for both methods (MethodDeclaration) and constructors (ConstructorDeclaration), but not for * Clinit objects, which are a vestigial eclipse thing that never contain anything. Static initializers * show up as 'Initializer', in the visitInitializer method, with modifier bit STATIC set. */ - void visitMethod(Node node, AbstractMethodDeclaration declaration); - void endVisitMethod(Node node, AbstractMethodDeclaration declaration); + void visitMethod(Node methodNode, AbstractMethodDeclaration method); + void visitAnnotationOnMethod(Node methodNode, AbstractMethodDeclaration method, Annotation annotation); + void endVisitMethod(Node methodNode, AbstractMethodDeclaration method); /** * Visits a local declaration - that is, something like 'int x = 10;' on the method level. Also called * for method parameter (those would be Arguments, a subclass of LocalDeclaration). */ - void visitLocal(Node node, LocalDeclaration declaration); - void endVisitLocal(Node node, LocalDeclaration declaration); + void visitLocal(Node localNode, LocalDeclaration local); + void visitAnnotationOnLocal(Node localNode, LocalDeclaration local, Annotation annotation); + void endVisitLocal(Node localNode, LocalDeclaration local); /** * Visits a statement that isn't any of the other visit methods (e.g. TypeDeclaration). * @param node * @param statement */ - void visitStatement(Node node, Statement statement); - void endVisitStatement(Node node, Statement statement); + void visitStatement(Node statementNode, Statement statement); + void endVisitStatement(Node statementNode, Statement statement); public static class EclipseASTPrinter implements EclipseASTVisitor { int indent = 0; @@ -112,6 +118,10 @@ public interface EclipseASTVisitor { indent++; } + @Override public void visitAnnotationOnType(Node node, TypeDeclaration type, Annotation annotation) { + print("<ANNOTATION: %s />", annotation); + } + @Override public void endVisitType(Node node, TypeDeclaration type) { indent--; print("</TYPE %s>", str(type.name)); @@ -136,6 +146,10 @@ public interface EclipseASTVisitor { indent++; } + @Override public void visitAnnotationOnField(Node node, FieldDeclaration field, Annotation annotation) { + print("<ANNOTATION: %s />", annotation); + } + @Override public void endVisitField(Node node, FieldDeclaration field) { indent--; print("</FIELD %s %s>", str(field.type), str(field.name)); @@ -147,6 +161,10 @@ public interface EclipseASTVisitor { indent++; } + @Override public void visitAnnotationOnMethod(Node node, AbstractMethodDeclaration method, Annotation annotation) { + print("<ANNOTATION: %s />", annotation); + } + @Override public void endVisitMethod(Node node, AbstractMethodDeclaration method) { String type = method instanceof ConstructorDeclaration ? "CONSTRUCTOR" : "METHOD"; indent--; @@ -159,6 +177,10 @@ public interface EclipseASTVisitor { indent++; } + @Override public void visitAnnotationOnLocal(Node node, LocalDeclaration local, Annotation annotation) { + print("<ANNOTATION: %s />", annotation); + } + @Override public void endVisitLocal(Node node, LocalDeclaration local) { String type = local instanceof Argument ? "ARGUMENT" : "LOCAL"; indent--; diff --git a/src/lombok/eclipse/TransformEclipseAST.java b/src/lombok/eclipse/TransformEclipseAST.java index f606733c..1a1561c3 100644 --- a/src/lombok/eclipse/TransformEclipseAST.java +++ b/src/lombok/eclipse/TransformEclipseAST.java @@ -107,36 +107,25 @@ public class TransformEclipseAST { } public void go() { +// if ( ast.getFileName().contains("Foo") ) ast.traverse(new EclipseASTVisitor.EclipseASTPrinter()); ast.traverse(new AnnotationVisitor()); } private static class AnnotationVisitor extends EclipseASTAdapter { - @Override public void visitField(Node node, FieldDeclaration field) { - if ( field.annotations == null ) return; - for ( Annotation annotation : field.annotations ) { - handlers.handle((CompilationUnitDeclaration) node.top().node, node, annotation); - } + @Override public void visitAnnotationOnField(Node node, FieldDeclaration field, Annotation annotation) { + handlers.handle((CompilationUnitDeclaration) node.top().node, node, annotation); } - @Override public void visitLocal(Node node, LocalDeclaration local) { - if ( local.annotations == null ) return; - for ( Annotation annotation : local.annotations ) { - handlers.handle((CompilationUnitDeclaration) node.top().node, node, annotation); - } + @Override public void visitAnnotationOnLocal(Node node, LocalDeclaration local, Annotation annotation) { + handlers.handle((CompilationUnitDeclaration) node.top().node, node, annotation); } - @Override public void visitMethod(Node node, AbstractMethodDeclaration method) { - if ( method.annotations == null ) return; - for ( Annotation annotation : method.annotations ) { - handlers.handle((CompilationUnitDeclaration) node.top().node, node, annotation); - } + @Override public void visitAnnotationOnMethod(Node node, AbstractMethodDeclaration method, Annotation annotation) { + handlers.handle((CompilationUnitDeclaration) node.top().node, node, annotation); } - @Override public void visitType(Node node, TypeDeclaration type) { - if ( type.annotations == null ) return; - for ( Annotation annotation : type.annotations ) { - handlers.handle((CompilationUnitDeclaration) node.top().node, node, annotation); - } + @Override public void visitAnnotationOnType(Node node, TypeDeclaration type, Annotation annotation) { + handlers.handle((CompilationUnitDeclaration) node.top().node, node, annotation); } } } |