# HG changeset patch # User jjg # Date 1266278990 28800 # Node ID 57f71400ba2928e00cb7bd08246cb498d4750238 # Parent b642d21c9f7498df064bb205a7c5eafc4c0bbe55 6926555: 6921979 breaks TreePosTest Reviewed-by: darcy diff -r b642d21c9f74 -r 57f71400ba29 langtools/test/tools/javac/treepostests/TreePosTest.java --- a/langtools/test/tools/javac/treepostests/TreePosTest.java Thu Feb 04 10:14:28 2010 -0800 +++ b/langtools/test/tools/javac/treepostests/TreePosTest.java Mon Feb 15 16:09:50 2010 -0800 @@ -98,7 +98,7 @@ * @test * @bug 6919889 * @summary assorted position errors in compiler syntax trees - * @run main TreePosTest -q -r -ef ./tools/javac/typeAnnotations -ef ./tools/javap/typeAnnotations . + * @run main TreePosTest -q -r -ef ./tools/javac/typeAnnotations -ef ./tools/javap/typeAnnotations -et ANNOTATED_TYPE . */ public class TreePosTest { /** @@ -150,6 +150,8 @@ tags.add(args[++i]); else if (arg.equals("-ef") && i + 1 < args.length) excludeFiles.add(new File(baseDir, args[++i])); + else if (arg.equals("-et") && i + 1 < args.length) + excludeTags.add(args[++i]); else if (arg.equals("-r")) { if (excludeFiles.size() > 0) throw new Error("-r must be used before -ef"); @@ -199,6 +201,7 @@ out.println("-t tag Limit checks to tree nodes with this tag"); out.println(" Can be repeated if desired"); out.println("-ef file Exclude file or directory"); + out.println("-et tag Exclude tree nodes with given tag name"); out.println(""); out.println("files may be directories or files"); out.println("directories will be scanned recursively"); @@ -304,6 +307,8 @@ Set tags = new HashSet(); /** Set of files and directories to be excluded from analysis. */ Set excludeFiles = new HashSet(); + /** Set of tag names to be excluded from analysis. */ + Set excludeTags = new HashSet(); /** Table of printable names for tree tag values. */ TagNames tagNames = new TagNames(); @@ -324,7 +329,7 @@ return; Info self = new Info(tree, endPosTable); - if (check(self)) { + if (check(encl, self)) { // Modifiers nodes are present throughout the tree even where // there is no corresponding source text. // Redundant semicolons in a class definition can cause empty @@ -392,8 +397,13 @@ super.visitVarDef(tree); } - boolean check(Info x) { - return tags.size() == 0 || tags.contains(tagNames.get(x.tag)); + boolean check(Info encl, Info self) { + if (excludeTags.size() > 0) { + if (encl != null && excludeTags.contains(tagNames.get(encl.tag)) + || excludeTags.contains(tagNames.get(self.tag))) + return false; + } + return tags.size() == 0 || tags.contains(tagNames.get(self.tag)); } void check(String label, Info encl, Info self, boolean ok) {