mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-20 11:04:34 +02:00
8033930: Unnecessary new line after the StackMapTable
8033913: Incorrect indentation of StackMapTable entries Reviewed-by: ksrini
This commit is contained in:
parent
c0d767f6f1
commit
4e86ae9988
2 changed files with 103 additions and 19 deletions
|
@ -531,7 +531,6 @@ public class AttributeWriter extends BasicWriter
|
||||||
for (StackMapTable_attribute.stack_map_frame entry : attr.entries) {
|
for (StackMapTable_attribute.stack_map_frame entry : attr.entries) {
|
||||||
w.write(entry);
|
w.write(entry);
|
||||||
}
|
}
|
||||||
println();
|
|
||||||
indent(-1);
|
indent(-1);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -543,7 +542,6 @@ public class AttributeWriter extends BasicWriter
|
||||||
for (StackMapTable_attribute.stack_map_frame entry : attr.entries) {
|
for (StackMapTable_attribute.stack_map_frame entry : attr.entries) {
|
||||||
w.write(entry);
|
w.write(entry);
|
||||||
}
|
}
|
||||||
println();
|
|
||||||
indent(-1);
|
indent(-1);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -555,14 +553,12 @@ public class AttributeWriter extends BasicWriter
|
||||||
}
|
}
|
||||||
|
|
||||||
public Void visit_same_frame(StackMapTable_attribute.same_frame frame, Void p) {
|
public Void visit_same_frame(StackMapTable_attribute.same_frame frame, Void p) {
|
||||||
printHeader(frame);
|
printHeader(frame, "/* same */");
|
||||||
println(" /* same */");
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Void visit_same_locals_1_stack_item_frame(StackMapTable_attribute.same_locals_1_stack_item_frame frame, Void p) {
|
public Void visit_same_locals_1_stack_item_frame(StackMapTable_attribute.same_locals_1_stack_item_frame frame, Void p) {
|
||||||
printHeader(frame);
|
printHeader(frame, "/* same_locals_1_stack_item */");
|
||||||
println(" /* same_locals_1_stack_item */");
|
|
||||||
indent(+1);
|
indent(+1);
|
||||||
printMap("stack", frame.stack);
|
printMap("stack", frame.stack);
|
||||||
indent(-1);
|
indent(-1);
|
||||||
|
@ -570,8 +566,7 @@ public class AttributeWriter extends BasicWriter
|
||||||
}
|
}
|
||||||
|
|
||||||
public Void visit_same_locals_1_stack_item_frame_extended(StackMapTable_attribute.same_locals_1_stack_item_frame_extended frame, Void p) {
|
public Void visit_same_locals_1_stack_item_frame_extended(StackMapTable_attribute.same_locals_1_stack_item_frame_extended frame, Void p) {
|
||||||
printHeader(frame);
|
printHeader(frame, "/* same_locals_1_stack_item_frame_extended */");
|
||||||
println(" /* same_locals_1_stack_item_frame_extended */");
|
|
||||||
indent(+1);
|
indent(+1);
|
||||||
println("offset_delta = " + frame.offset_delta);
|
println("offset_delta = " + frame.offset_delta);
|
||||||
printMap("stack", frame.stack);
|
printMap("stack", frame.stack);
|
||||||
|
@ -580,8 +575,7 @@ public class AttributeWriter extends BasicWriter
|
||||||
}
|
}
|
||||||
|
|
||||||
public Void visit_chop_frame(StackMapTable_attribute.chop_frame frame, Void p) {
|
public Void visit_chop_frame(StackMapTable_attribute.chop_frame frame, Void p) {
|
||||||
printHeader(frame);
|
printHeader(frame, "/* chop */");
|
||||||
println(" /* chop */");
|
|
||||||
indent(+1);
|
indent(+1);
|
||||||
println("offset_delta = " + frame.offset_delta);
|
println("offset_delta = " + frame.offset_delta);
|
||||||
indent(-1);
|
indent(-1);
|
||||||
|
@ -589,8 +583,7 @@ public class AttributeWriter extends BasicWriter
|
||||||
}
|
}
|
||||||
|
|
||||||
public Void visit_same_frame_extended(StackMapTable_attribute.same_frame_extended frame, Void p) {
|
public Void visit_same_frame_extended(StackMapTable_attribute.same_frame_extended frame, Void p) {
|
||||||
printHeader(frame);
|
printHeader(frame, "/* same_frame_extended */");
|
||||||
println(" /* same_frame_extended */");
|
|
||||||
indent(+1);
|
indent(+1);
|
||||||
println("offset_delta = " + frame.offset_delta);
|
println("offset_delta = " + frame.offset_delta);
|
||||||
indent(-1);
|
indent(-1);
|
||||||
|
@ -598,8 +591,7 @@ public class AttributeWriter extends BasicWriter
|
||||||
}
|
}
|
||||||
|
|
||||||
public Void visit_append_frame(StackMapTable_attribute.append_frame frame, Void p) {
|
public Void visit_append_frame(StackMapTable_attribute.append_frame frame, Void p) {
|
||||||
printHeader(frame);
|
printHeader(frame, "/* append */");
|
||||||
println(" /* append */");
|
|
||||||
indent(+1);
|
indent(+1);
|
||||||
println("offset_delta = " + frame.offset_delta);
|
println("offset_delta = " + frame.offset_delta);
|
||||||
printMap("locals", frame.locals);
|
printMap("locals", frame.locals);
|
||||||
|
@ -608,12 +600,11 @@ public class AttributeWriter extends BasicWriter
|
||||||
}
|
}
|
||||||
|
|
||||||
public Void visit_full_frame(StackMapTable_attribute.full_frame frame, Void p) {
|
public Void visit_full_frame(StackMapTable_attribute.full_frame frame, Void p) {
|
||||||
printHeader(frame);
|
|
||||||
if (frame instanceof StackMap_attribute.stack_map_frame) {
|
if (frame instanceof StackMap_attribute.stack_map_frame) {
|
||||||
|
printHeader(frame, "offset = " + frame.offset_delta);
|
||||||
indent(+1);
|
indent(+1);
|
||||||
println(" offset = " + frame.offset_delta);
|
|
||||||
} else {
|
} else {
|
||||||
println(" /* full_frame */");
|
printHeader(frame, "/* full_frame */");
|
||||||
indent(+1);
|
indent(+1);
|
||||||
println("offset_delta = " + frame.offset_delta);
|
println("offset_delta = " + frame.offset_delta);
|
||||||
}
|
}
|
||||||
|
@ -623,8 +614,9 @@ public class AttributeWriter extends BasicWriter
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
void printHeader(StackMapTable_attribute.stack_map_frame frame) {
|
void printHeader(StackMapTable_attribute.stack_map_frame frame, String extra) {
|
||||||
print(" frame_type = " + frame.frame_type);
|
print("frame_type = " + frame.frame_type + " ");
|
||||||
|
println(extra);
|
||||||
}
|
}
|
||||||
|
|
||||||
void printMap(String name, StackMapTable_attribute.verification_type_info[] map) {
|
void printMap(String name, StackMapTable_attribute.verification_type_info[] map) {
|
||||||
|
|
92
langtools/test/tools/javap/StackMapTableTest.java
Normal file
92
langtools/test/tools/javap/StackMapTableTest.java
Normal file
|
@ -0,0 +1,92 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2014, Oracle and/or its affiliates. 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 8033930 8033913
|
||||||
|
* @summary bad formatting of StackMapTable entries
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
public class StackMapTableTest {
|
||||||
|
public static void main(String... args) throws Exception {
|
||||||
|
new StackMapTableTest().run();
|
||||||
|
}
|
||||||
|
|
||||||
|
void run() throws Exception {
|
||||||
|
String testClasses = System.getProperty("test.classes");
|
||||||
|
String out = javap("-v", "-classpath", testClasses, A.class.getName());
|
||||||
|
|
||||||
|
String nl = System.getProperty("line.separator");
|
||||||
|
out = out.replaceAll(nl, "\n");
|
||||||
|
|
||||||
|
if (out.contains("\n\n\n"))
|
||||||
|
error("double blank line found");
|
||||||
|
|
||||||
|
String expect =
|
||||||
|
" StackMapTable: number_of_entries = 2\n" +
|
||||||
|
" frame_type = 252 /* append */\n" +
|
||||||
|
" offset_delta = 2\n" +
|
||||||
|
" locals = [ int ]\n" +
|
||||||
|
" frame_type = 250 /* chop */\n" +
|
||||||
|
" offset_delta = 18\n";
|
||||||
|
if (!out.contains(expect))
|
||||||
|
error("expected text not found");
|
||||||
|
|
||||||
|
if (errors > 0)
|
||||||
|
throw new Exception(errors + " errors found");
|
||||||
|
}
|
||||||
|
|
||||||
|
String javap(String... args) throws Exception {
|
||||||
|
StringWriter sw = new StringWriter();
|
||||||
|
PrintWriter out = new PrintWriter(sw);
|
||||||
|
int rc = com.sun.tools.javap.Main.run(args, out);
|
||||||
|
out.close();
|
||||||
|
System.out.println(sw.toString());
|
||||||
|
if (rc < 0)
|
||||||
|
throw new Exception("javap exited, rc=" + rc);
|
||||||
|
return sw.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
void error(String msg) {
|
||||||
|
System.out.println("Error: " + msg);
|
||||||
|
errors++;
|
||||||
|
}
|
||||||
|
|
||||||
|
int errors;
|
||||||
|
|
||||||
|
/** Simple test class to run through javap. */
|
||||||
|
public class A {
|
||||||
|
public void a() {
|
||||||
|
for (int i = 0; i < 10; i++) {
|
||||||
|
System.out.println(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void b() {
|
||||||
|
}
|
||||||
|
public void c() {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue