6902264: fix indentation of tableswitch and lookupswitch
Reviewed-by: ksrini
This commit is contained in:
parent
538c9dbddf
commit
ea8f607432
@ -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();
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user