mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-09 00:14:10 -08:00
https://github.com/konsoletyper/teavm/issues/22 https://github.com/konsoletyper/teavm/issues/21
This commit is contained in:
parent
70338531f5
commit
581cae0ef4
|
@ -365,4 +365,9 @@ public class StringBuilderTest {
|
||||||
assertEquals(3, sb.lastIndexOf("345"));
|
assertEquals(3, sb.lastIndexOf("345"));
|
||||||
assertEquals(-1, sb.lastIndexOf("35"));
|
assertEquals(-1, sb.lastIndexOf("35"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void substringWithUpperBoundAtEndWorks() {
|
||||||
|
assertEquals("23", "123".substring(1, 3));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,4 +67,20 @@ public class VMTest {
|
||||||
// do nothing
|
// do nothing
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void setsVariableBeforeTryCatch() {
|
||||||
|
int a = 23;
|
||||||
|
try {
|
||||||
|
a = Integer.parseInt("not a number");
|
||||||
|
} catch (NumberFormatException e) {
|
||||||
|
// do nothing
|
||||||
|
}
|
||||||
|
assertEquals(23, a);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void surrogateInStringLiteralsWork() {
|
||||||
|
assertEquals(0xDDC2, "a\uDDC2b".charAt(1));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -245,7 +245,7 @@ public class Decompiler {
|
||||||
if (node >= 0) {
|
if (node >= 0) {
|
||||||
generator.currentBlock = program.basicBlockAt(node);
|
generator.currentBlock = program.basicBlockAt(node);
|
||||||
int tmp = indexer.nodeAt(next);
|
int tmp = indexer.nodeAt(next);
|
||||||
generator.nextBlock = next < indexer.size() ? program.basicBlockAt(tmp) : null;
|
generator.nextBlock = tmp >= 0 && next < indexer.size() ? program.basicBlockAt(tmp) : null;
|
||||||
generator.statements.clear();
|
generator.statements.clear();
|
||||||
InstructionLocation lastLocation = null;
|
InstructionLocation lastLocation = null;
|
||||||
NodeLocation nodeLocation = null;
|
NodeLocation nodeLocation = null;
|
||||||
|
|
|
@ -1252,6 +1252,12 @@ public class Renderer implements ExprVisitor, StatementVisitor, RenderingContext
|
||||||
if (c < ' ') {
|
if (c < ' ') {
|
||||||
sb.append("\\u00").append(Character.forDigit(c / 16, 16))
|
sb.append("\\u00").append(Character.forDigit(c / 16, 16))
|
||||||
.append(Character.forDigit(c % 16, 16));
|
.append(Character.forDigit(c % 16, 16));
|
||||||
|
} else if (Character.isLowSurrogate(c) || Character.isHighSurrogate(c)) {
|
||||||
|
sb.append("\\u")
|
||||||
|
.append(Character.forDigit(c / 0x1000, 0x10))
|
||||||
|
.append(Character.forDigit((c / 0x100) % 0x10, 0x10))
|
||||||
|
.append(Character.forDigit((c / 0x10) % 0x10, 0x10))
|
||||||
|
.append(Character.forDigit(c % 0x10, 0x10));
|
||||||
} else {
|
} else {
|
||||||
sb.append(c);
|
sb.append(c);
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,24 +29,6 @@ public final class ProgramUtils {
|
||||||
private ProgramUtils() {
|
private ProgramUtils() {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Graph buildControlFlowGraphWithoutTryCatch(Program program) {
|
|
||||||
GraphBuilder graphBuilder = new GraphBuilder(program.basicBlockCount());
|
|
||||||
InstructionTransitionExtractor transitionExtractor = new InstructionTransitionExtractor();
|
|
||||||
for (int i = 0; i < program.basicBlockCount(); ++i) {
|
|
||||||
BasicBlock block = program.basicBlockAt(i);
|
|
||||||
Instruction insn = block.getLastInstruction();
|
|
||||||
if (insn != null) {
|
|
||||||
insn.acceptVisitor(transitionExtractor);
|
|
||||||
if (transitionExtractor.getTargets() != null) {
|
|
||||||
for (BasicBlock successor : transitionExtractor.getTargets()) {
|
|
||||||
graphBuilder.addEdge(i, successor.getIndex());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return graphBuilder.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Graph buildControlFlowGraph(Program program) {
|
public static Graph buildControlFlowGraph(Program program) {
|
||||||
GraphBuilder graphBuilder = new GraphBuilder(program.basicBlockCount());
|
GraphBuilder graphBuilder = new GraphBuilder(program.basicBlockCount());
|
||||||
InstructionTransitionExtractor transitionExtractor = new InstructionTransitionExtractor();
|
InstructionTransitionExtractor transitionExtractor = new InstructionTransitionExtractor();
|
||||||
|
@ -68,6 +50,30 @@ public final class ProgramUtils {
|
||||||
return graphBuilder.build();
|
return graphBuilder.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Graph buildControlFlowGraphWithTryCatch(Program program) {
|
||||||
|
GraphBuilder graphBuilder = new GraphBuilder(program.basicBlockCount());
|
||||||
|
InstructionTransitionExtractor transitionExtractor = new InstructionTransitionExtractor();
|
||||||
|
for (int i = 0; i < program.basicBlockCount(); ++i) {
|
||||||
|
BasicBlock block = program.basicBlockAt(i);
|
||||||
|
Instruction insn = block.getLastInstruction();
|
||||||
|
if (insn != null) {
|
||||||
|
insn.acceptVisitor(transitionExtractor);
|
||||||
|
if (transitionExtractor.getTargets() != null) {
|
||||||
|
for (BasicBlock successor : transitionExtractor.getTargets()) {
|
||||||
|
graphBuilder.addEdge(i, successor.getIndex());
|
||||||
|
for (TryCatchBlock succTryCatch : successor.getTryCatchBlocks()) {
|
||||||
|
graphBuilder.addEdge(i, succTryCatch.getHandler().getIndex());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (TryCatchBlock tryCatch : block.getTryCatchBlocks()) {
|
||||||
|
graphBuilder.addEdge(i, tryCatch.getHandler().getIndex());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return graphBuilder.build();
|
||||||
|
}
|
||||||
|
|
||||||
public static Map<InstructionLocation, InstructionLocation[]> getLocationCFG(Program program) {
|
public static Map<InstructionLocation, InstructionLocation[]> getLocationCFG(Program program) {
|
||||||
return new LocationGraphBuilder().build(program);
|
return new LocationGraphBuilder().build(program);
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,7 +49,7 @@ public class SSATransformer {
|
||||||
this.variableDebugInfo = variableDebugInfo;
|
this.variableDebugInfo = variableDebugInfo;
|
||||||
this.arguments = arguments;
|
this.arguments = arguments;
|
||||||
variableDebugMap.clear();
|
variableDebugMap.clear();
|
||||||
cfg = ProgramUtils.buildControlFlowGraphWithoutTryCatch(program);
|
cfg = ProgramUtils.buildControlFlowGraphWithTryCatch(program);
|
||||||
domTree = GraphUtils.buildDominatorTree(cfg);
|
domTree = GraphUtils.buildDominatorTree(cfg);
|
||||||
domFrontiers = new int[cfg.size()][];
|
domFrontiers = new int[cfg.size()][];
|
||||||
variableMap = new Variable[program.variableCount()];
|
variableMap = new Variable[program.variableCount()];
|
||||||
|
|
Loading…
Reference in New Issue
Block a user