6902264: fix indentation of tableswitch and lookupswitch

Reviewed-by: ksrini
This commit is contained in:
Jonathan Gibbons 2009-11-19 11:38:38 -08:00
parent 538c9dbddf
commit ea8f607432
2 changed files with 34 additions and 27 deletions

View File

@ -106,9 +106,9 @@ public class Instruction {
/** See {@link Kind#LOCAL_UBYTE}. */ /** See {@link Kind#LOCAL_UBYTE}. */
R visitLocalAndValue(Instruction instr, int index, int value, P p); R visitLocalAndValue(Instruction instr, int index, int value, P p);
/** See {@link Kind#DYNAMIC}. */ /** See {@link Kind#DYNAMIC}. */
R visitLookupSwitch(Instruction instr, int default_, int npairs, int[] matches, int[] offsets); R visitLookupSwitch(Instruction instr, int default_, int npairs, int[] matches, int[] offsets, P p);
/** See {@link Kind#DYNAMIC}. */ /** See {@link Kind#DYNAMIC}. */
R visitTableSwitch(Instruction instr, int default_, int low, int high, int[] offsets); R visitTableSwitch(Instruction instr, int default_, int low, int high, int[] offsets, P p);
/** See {@link Kind#BYTE}, {@link Kind#SHORT}. */ /** See {@link Kind#BYTE}, {@link Kind#SHORT}. */
R visitValue(Instruction instr, int value, P p); R visitValue(Instruction instr, int value, P p);
/** Instruction is unrecognized. */ /** Instruction is unrecognized. */
@ -282,7 +282,7 @@ public class Instruction {
for (int i = 0; i < values.length; i++) for (int i = 0; i < values.length; i++)
values[i] = getInt(pad + 12 + 4 * i); values[i] = getInt(pad + 12 + 4 * i);
return visitor.visitTableSwitch( return visitor.visitTableSwitch(
this, default_, low, high, values); this, default_, low, high, values, p);
} }
case LOOKUPSWITCH: { case LOOKUPSWITCH: {
int pad = align(pc + 1) - pc; int pad = align(pc + 1) - pc;
@ -295,7 +295,7 @@ public class Instruction {
offsets[i] = getInt(pad + 12 + i * 8); offsets[i] = getInt(pad + 12 + i * 8);
} }
return visitor.visitLookupSwitch( return visitor.visitLookupSwitch(
this, default_, npairs, matches, offsets); this, default_, npairs, matches, offsets, p);
} }
default: default:
throw new IllegalStateException(); throw new IllegalStateException();

View File

@ -118,28 +118,33 @@ class CodeWriter extends BasicWriter {
public void writeInstr(Instruction instr) { public void writeInstr(Instruction instr) {
print(String.format("%4d: %-13s ", instr.getPC(), instr.getMnemonic())); print(String.format("%4d: %-13s ", instr.getPC(), instr.getMnemonic()));
instr.accept(instructionPrinter, null); // compute the number of indentations for the body of multi-line instructions
// This is 6 (the width of "%4d: "), divided by the width of each indentation level,
// and rounded up to the next integer.
int indentWidth = options.indentWidth;
int indent = (6 + indentWidth - 1) / indentWidth;
instr.accept(instructionPrinter, indent);
println(); println();
} }
// where // where
Instruction.KindVisitor<Void,Void> instructionPrinter = Instruction.KindVisitor<Void,Integer> instructionPrinter =
new Instruction.KindVisitor<Void,Void>() { new Instruction.KindVisitor<Void,Integer>() {
public Void visitNoOperands(Instruction instr, Void p) { public Void visitNoOperands(Instruction instr, Integer indent) {
return null; return null;
} }
public Void visitArrayType(Instruction instr, TypeKind kind, Void p) { public Void visitArrayType(Instruction instr, TypeKind kind, Integer indent) {
print(" " + kind.name); print(" " + kind.name);
return null; return null;
} }
public Void visitBranch(Instruction instr, int offset, Void p) { public Void visitBranch(Instruction instr, int offset, Integer indent) {
print((instr.getPC() + offset)); print((instr.getPC() + offset));
return null; return null;
} }
public Void visitConstantPoolRef(Instruction instr, int index, Void p) { public Void visitConstantPoolRef(Instruction instr, int index, Integer indent) {
print("#" + index); print("#" + index);
tab(); tab();
print("// "); print("// ");
@ -147,7 +152,7 @@ class CodeWriter extends BasicWriter {
return null; return null;
} }
public Void visitConstantPoolRefAndValue(Instruction instr, int index, int value, Void p) { public Void visitConstantPoolRefAndValue(Instruction instr, int index, int value, Integer indent) {
print("#" + index + ", " + value); print("#" + index + ", " + value);
tab(); tab();
print("// "); print("// ");
@ -155,46 +160,48 @@ class CodeWriter extends BasicWriter {
return null; return null;
} }
public Void visitLocal(Instruction instr, int index, Void p) { public Void visitLocal(Instruction instr, int index, Integer indent) {
print(index); print(index);
return null; return null;
} }
public Void visitLocalAndValue(Instruction instr, int index, int value, Void p) { public Void visitLocalAndValue(Instruction instr, int index, int value, Integer indent) {
print(index + ", " + value); print(index + ", " + value);
return null; return null;
} }
public Void visitLookupSwitch(Instruction instr, int default_, int npairs, int[] matches, int[] offsets) { public Void visitLookupSwitch(Instruction instr,
int default_, int npairs, int[] matches, int[] offsets, Integer indent) {
int pc = instr.getPC(); int pc = instr.getPC();
print("{ // " + npairs); print("{ // " + npairs);
indent(+1); indent(indent);
for (int i = 0; i < npairs; i++) { for (int i = 0; i < npairs; i++) {
print("\n" + matches[i] + ": " + (pc + offsets[i])); print(String.format("%n%12d: %d", matches[i], (pc + offsets[i])));
} }
print("\ndefault: " + (pc + default_) + " }"); print("\n default: " + (pc + default_) + "\n}");
indent(-1); indent(-indent);
return null; return null;
} }
public Void visitTableSwitch(Instruction instr, int default_, int low, int high, int[] offsets) { public Void visitTableSwitch(Instruction instr,
int default_, int low, int high, int[] offsets, Integer indent) {
int pc = instr.getPC(); int pc = instr.getPC();
print("{ // " + low + " to " + high); print("{ // " + low + " to " + high);
indent(+1); indent(indent);
for (int i = 0; i < offsets.length; i++) { for (int i = 0; i < offsets.length; i++) {
print("\n" + (low + i) + ": " + (pc + offsets[i])); print(String.format("%n%12d: %d", (low + i), (pc + offsets[i])));
} }
print("\ndefault: " + (pc + default_) + " }"); print("\n default: " + (pc + default_) + "\n}");
indent(-1); indent(-indent);
return null; return null;
} }
public Void visitValue(Instruction instr, int value, Void p) { public Void visitValue(Instruction instr, int value, Integer indent) {
print(value); print(value);
return null; return null;
} }
public Void visitUnknown(Instruction instr, Void p) { public Void visitUnknown(Instruction instr, Integer indent) {
return null; return null;
} }
}; };