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
|
/** Set when we are producing source output. If we're not
|
||||||
* producing source output, we can sometimes give more detail in
|
* producing source output, we can sometimes give more detail in
|
||||||
* the output even though that detail would not be valid java
|
* the output even though that detail would not be valid java
|
||||||
* soruce.
|
* source.
|
||||||
*/
|
*/
|
||||||
private final boolean sourceOutput;
|
private final boolean sourceOutput;
|
||||||
|
|
||||||
@ -489,6 +489,20 @@ public class Pretty extends JCTree.Visitor {
|
|||||||
print("/*public static final*/ ");
|
print("/*public static final*/ ");
|
||||||
print(tree.name);
|
print(tree.name);
|
||||||
if (tree.init != null) {
|
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(" /* = ");
|
print(" /* = ");
|
||||||
printExpr(tree.init);
|
printExpr(tree.init);
|
||||||
print(" */");
|
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