aboutsummaryrefslogtreecommitdiff
path: root/src/lombok
diff options
context:
space:
mode:
authorReinier Zwitserloot <reinier@tipit.to>2009-07-01 15:58:24 +0200
committerReinier Zwitserloot <reinier@tipit.to>2009-07-01 15:58:24 +0200
commit34780e3ab5c549dd83085fe0893e015d3ef4d211 (patch)
treea65018fff52d22f225ef8175c07adda87d22048d /src/lombok
parentdb4819183f698acea6221656098e6e42a6e9e6fd (diff)
downloadlombok-34780e3ab5c549dd83085fe0893e015d3ef4d211.tar.gz
lombok-34780e3ab5c549dd83085fe0893e015d3ef4d211.tar.bz2
lombok-34780e3ab5c549dd83085fe0893e015d3ef4d211.zip
Added a bonus feature to @Cleanup: Assigning a @Cleanup marked variable to anything else generates a warning.
Diffstat (limited to 'src/lombok')
-rw-r--r--src/lombok/eclipse/handlers/HandleCleanup.java26
-rw-r--r--src/lombok/javac/handlers/HandleCleanup.java26
2 files changed, 52 insertions, 0 deletions
diff --git a/src/lombok/eclipse/handlers/HandleCleanup.java b/src/lombok/eclipse/handlers/HandleCleanup.java
index a28c6c6a..fa97e76d 100644
--- a/src/lombok/eclipse/handlers/HandleCleanup.java
+++ b/src/lombok/eclipse/handlers/HandleCleanup.java
@@ -1,5 +1,7 @@
package lombok.eclipse.handlers;
+import java.util.Arrays;
+
import lombok.Cleanup;
import lombok.core.AnnotationValues;
import lombok.core.AST.Kind;
@@ -9,8 +11,10 @@ import lombok.eclipse.EclipseAST.Node;
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.Assignment;
import org.eclipse.jdt.internal.compiler.ast.Block;
import org.eclipse.jdt.internal.compiler.ast.CaseStatement;
+import org.eclipse.jdt.internal.compiler.ast.CastExpression;
import org.eclipse.jdt.internal.compiler.ast.LocalDeclaration;
import org.eclipse.jdt.internal.compiler.ast.MessageSend;
import org.eclipse.jdt.internal.compiler.ast.SingleNameReference;
@@ -97,6 +101,8 @@ public class HandleCleanup implements EclipseAnnotationHandler<Cleanup> {
System.arraycopy(statements, 0, newStatements, 0, start); //copy all statements before the try block verbatim.
System.arraycopy(statements, end, newStatements, start+1, statements.length - end); //For switch statements.
+ doAssignmentCheck(annotationNode, tryBlock, decl.name);
+
TryStatement tryStatement = new TryStatement();
tryStatement.tryBlock = new Block(0);
tryStatement.tryBlock.statements = tryBlock;
@@ -126,4 +132,24 @@ public class HandleCleanup implements EclipseAnnotationHandler<Cleanup> {
return true;
}
+
+ private void doAssignmentCheck(Node node, Statement[] tryBlock, char[] varName) {
+ for ( Statement statement : tryBlock ) doAssignmentCheck0(node, statement, varName);
+ }
+
+ private void doAssignmentCheck0(Node node, Statement statement, char[] varName) {
+ if ( statement instanceof Assignment )
+ doAssignmentCheck0(node, ((Assignment)statement).expression, varName);
+ else if ( statement instanceof LocalDeclaration )
+ doAssignmentCheck0(node, ((LocalDeclaration)statement).initialization, varName);
+ else if ( statement instanceof CastExpression )
+ doAssignmentCheck0(node, ((CastExpression)statement).expression, varName);
+ else if ( statement instanceof SingleNameReference ) {
+ if ( Arrays.equals(((SingleNameReference)statement).token, varName) ) {
+ Node problemNode = node.getNodeFor(statement);
+ if ( problemNode != null ) problemNode.addWarning(
+ "You're assigning a guarded variable to something else. This is a bad idea.");
+ }
+ }
+ }
}
diff --git a/src/lombok/javac/handlers/HandleCleanup.java b/src/lombok/javac/handlers/HandleCleanup.java
index 3035a1b0..9a8cf516 100644
--- a/src/lombok/javac/handlers/HandleCleanup.java
+++ b/src/lombok/javac/handlers/HandleCleanup.java
@@ -11,15 +11,20 @@ import org.mangosdk.spi.ProviderFor;
import com.sun.tools.javac.tree.JCTree;
import com.sun.tools.javac.tree.TreeMaker;
import com.sun.tools.javac.tree.JCTree.JCAnnotation;
+import com.sun.tools.javac.tree.JCTree.JCAssign;
import com.sun.tools.javac.tree.JCTree.JCBlock;
import com.sun.tools.javac.tree.JCTree.JCCase;
import com.sun.tools.javac.tree.JCTree.JCCatch;
import com.sun.tools.javac.tree.JCTree.JCExpression;
+import com.sun.tools.javac.tree.JCTree.JCExpressionStatement;
import com.sun.tools.javac.tree.JCTree.JCFieldAccess;
+import com.sun.tools.javac.tree.JCTree.JCIdent;
import com.sun.tools.javac.tree.JCTree.JCMethodDecl;
import com.sun.tools.javac.tree.JCTree.JCStatement;
+import com.sun.tools.javac.tree.JCTree.JCTypeCast;
import com.sun.tools.javac.tree.JCTree.JCVariableDecl;
import com.sun.tools.javac.util.List;
+import com.sun.tools.javac.util.Name;
@ProviderFor(JavacAnnotationHandler.class)
public class HandleCleanup implements JavacAnnotationHandler<Cleanup> {
@@ -67,6 +72,8 @@ public class HandleCleanup implements JavacAnnotationHandler<Cleanup> {
return true;
}
+ doAssignmentCheck(annotationNode, tryBlock, decl.name);
+
TreeMaker maker = annotationNode.getTreeMaker();
JCFieldAccess cleanupCall = maker.Select(maker.Ident(decl.name), annotationNode.toName(cleanupName));
List<JCStatement> finalizerBlock = List.<JCStatement>of(maker.Exec(
@@ -87,4 +94,23 @@ public class HandleCleanup implements JavacAnnotationHandler<Cleanup> {
return true;
}
+
+ private void doAssignmentCheck(Node node, List<JCStatement> statements, Name name) {
+ for ( JCStatement statement : statements ) doAssignmentCheck0(node, statement, name);
+ }
+
+ private void doAssignmentCheck0(Node node, JCTree statement, Name name) {
+ if ( statement instanceof JCAssign ) doAssignmentCheck0(node, ((JCAssign)statement).rhs, name);
+ if ( statement instanceof JCExpressionStatement ) doAssignmentCheck0(node,
+ ((JCExpressionStatement)statement).expr, name);
+ if ( statement instanceof JCVariableDecl ) doAssignmentCheck0(node, ((JCVariableDecl)statement).init, name);
+ if ( statement instanceof JCTypeCast ) doAssignmentCheck0(node, ((JCTypeCast)statement).expr, name);
+ if ( statement instanceof JCIdent ) {
+ if ( ((JCIdent)statement).name.contentEquals(name) ) {
+ Node problemNode = node.getNodeFor(statement);
+ if ( problemNode != null ) problemNode.addWarning(
+ "You're assigning a guarded variable to something else. This is a bad idea.");
+ }
+ }
+ }
}