6902720: javac pretty printer does not handle enums correctly
Reviewed-by: mcimadamore
This commit is contained in:
parent
26a6e8a198
commit
a502ed59ba
@ -54,7 +54,7 @@ public class Pretty extends JCTree.Visitor {
|
||||
/** Set when we are producing source output. If we're not
|
||||
* producing source output, we can sometimes give more detail in
|
||||
* the output even though that detail would not be valid java
|
||||
* soruce.
|
||||
* source.
|
||||
*/
|
||||
private final boolean sourceOutput;
|
||||
|
||||
@ -489,6 +489,20 @@ public class Pretty extends JCTree.Visitor {
|
||||
print("/*public static final*/ ");
|
||||
print(tree.name);
|
||||
if (tree.init != null) {
|
||||
if (sourceOutput && tree.init.getTag() == JCTree.NEWCLASS) {
|
||||
print(" /*enum*/ ");
|
||||
JCNewClass init = (JCNewClass) tree.init;
|
||||
if (init.args != null && init.args.nonEmpty()) {
|
||||
print("(");
|
||||
print(init.args);
|
||||
print(")");
|
||||
}
|
||||
if (init.def != null && init.def.defs != null) {
|
||||
print(" ");
|
||||
printBlock(init.def.defs);
|
||||
}
|
||||
return;
|
||||
}
|
||||
print(" /* = ");
|
||||
printExpr(tree.init);
|
||||
print(" */");
|
||||
|
28
langtools/test/tools/javac/6902720/E1.java
Normal file
28
langtools/test/tools/javac/6902720/E1.java
Normal file
@ -0,0 +1,28 @@
|
||||
/*
|
||||
* Copyright 2009 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
* have any questions.
|
||||
*/
|
||||
|
||||
enum E1 {
|
||||
A,
|
||||
B { },
|
||||
C { void m() { } };
|
||||
}
|
29
langtools/test/tools/javac/6902720/E2.java
Normal file
29
langtools/test/tools/javac/6902720/E2.java
Normal file
@ -0,0 +1,29 @@
|
||||
/*
|
||||
* Copyright 2009 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
* have any questions.
|
||||
*/
|
||||
|
||||
enum E2 {
|
||||
A(1),
|
||||
B(2) { },
|
||||
C(3) { void m() { } };
|
||||
E2(int i) { }
|
||||
}
|
91
langtools/test/tools/javac/6902720/Test.java
Normal file
91
langtools/test/tools/javac/6902720/Test.java
Normal file
@ -0,0 +1,91 @@
|
||||
/*
|
||||
* Copyright 2009 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
* have any questions.
|
||||
*/
|
||||
|
||||
import java.io.*;
|
||||
import java.net.*;
|
||||
import javax.tools.*;
|
||||
import java.util.*;
|
||||
|
||||
import com.sun.source.tree.CompilationUnitTree;
|
||||
import com.sun.source.util.JavacTask;
|
||||
import com.sun.tools.javac.api.JavacTool;
|
||||
import com.sun.tools.javac.tree.JCTree;
|
||||
import com.sun.tools.javac.tree.Pretty;
|
||||
|
||||
/**
|
||||
* @test
|
||||
* @bug 6902720
|
||||
* @summary javac pretty printer does not handle enums correctly
|
||||
*/
|
||||
|
||||
public class Test {
|
||||
|
||||
public static void main(String[] args) throws Exception {
|
||||
Test t = new Test();
|
||||
t.run("E1.java", "E2.java");
|
||||
}
|
||||
|
||||
void run(String... args) throws Exception {
|
||||
File testSrcDir = new File(System.getProperty("test.src"));
|
||||
for (String arg: args) {
|
||||
test(new File(testSrcDir, arg));
|
||||
}
|
||||
}
|
||||
|
||||
void test(File test) throws Exception {
|
||||
JavacTool tool1 = JavacTool.create();
|
||||
StandardJavaFileManager fm = tool1.getStandardFileManager(null, null, null);
|
||||
Iterable<? extends JavaFileObject> files = fm.getJavaFileObjects(test);
|
||||
|
||||
// parse test file into a tree, and write it out to a stringbuffer using Pretty
|
||||
JavacTask t1 = tool1.getTask(null, fm, null, null, null, files);
|
||||
StringWriter sw = new StringWriter();
|
||||
PrintWriter pw = new PrintWriter(sw);
|
||||
Iterable<? extends CompilationUnitTree> trees = t1.parse();
|
||||
for (CompilationUnitTree tree: trees) {
|
||||
new Pretty(pw, true).printExpr((JCTree) tree);
|
||||
}
|
||||
pw.close();
|
||||
|
||||
final String out = sw.toString();
|
||||
System.err.println("generated code:\n" + out + "\n");
|
||||
|
||||
// verify the generated code is valid Java by compiling it
|
||||
JavacTool tool2 = JavacTool.create();
|
||||
JavaFileObject fo = new SimpleJavaFileObject(URI.create("output"), JavaFileObject.Kind.SOURCE) {
|
||||
@Override
|
||||
public CharSequence getCharContent(boolean ignoreEncodingErrors) {
|
||||
return out;
|
||||
}
|
||||
};
|
||||
JavacTask t2 = tool2.getTask(null, fm, null, null, null, Collections.singleton(fo));
|
||||
boolean ok = t2.call();
|
||||
if (!ok)
|
||||
throw new Exception("compilation of generated code failed");
|
||||
|
||||
File expectedClass = new File(test.getName().replace(".java", ".class"));
|
||||
if (!expectedClass.exists())
|
||||
throw new Exception(expectedClass + " not found");
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user