mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2024-12-31 12:24:10 -08:00
Adds VM test that verifies that exceptions are caught
This commit is contained in:
parent
62686878c6
commit
ea3e6adb64
|
@ -58,4 +58,13 @@ public class VMTest {
|
||||||
long b = 1836311903;
|
long b = 1836311903;
|
||||||
assertEquals(2971215073L, a + b);
|
assertEquals(2971215073L, a + b);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void catchesException() {
|
||||||
|
try {
|
||||||
|
throw new IllegalArgumentException();
|
||||||
|
} catch (IllegalArgumentException e) {
|
||||||
|
// do nothing
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,6 +53,10 @@ class ReadWriteStatsBuilder {
|
||||||
reads[incoming.getValue().getIndex()]++;
|
reads[incoming.getValue().getIndex()]++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
for (TryCatchBlock tryCatch : block.getTryCatchBlocks()) {
|
||||||
|
writes[tryCatch.getExceptionVariable().getIndex()]++;
|
||||||
|
reads[tryCatch.getExceptionVariable().getIndex()]++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1264,16 +1264,17 @@ public class Renderer implements ExprVisitor, StatementVisitor {
|
||||||
for (Statement part : protectedBody) {
|
for (Statement part : protectedBody) {
|
||||||
part.acceptVisitor(this);
|
part.acceptVisitor(this);
|
||||||
}
|
}
|
||||||
String var = variableName(statement.getExceptionVariable());
|
writer.outdent().append("}").ws().append("catch").ws().append("($e)")
|
||||||
writer.outdent().append("}").ws().append("catch").ws().append("(").append(var).append(")")
|
|
||||||
.ws().append("{").indent().softNewLine();
|
.ws().append("{").indent().softNewLine();
|
||||||
|
writer.append("$je").ws().append("=").ws().append("$e.$javaException;").softNewLine();
|
||||||
for (TryCatchStatement catchClause : sequence) {
|
for (TryCatchStatement catchClause : sequence) {
|
||||||
writer.append("if").ws().append("(").append(var).append(" instanceof ")
|
writer.append("if").ws().append("($je && $je instanceof ").appendClass(catchClause.getExceptionType())
|
||||||
.appendClass(catchClause.getExceptionType()).append(")").ws().append("{")
|
.append(")").ws().append("{").indent().softNewLine();
|
||||||
.indent().softNewLine();
|
|
||||||
if (statement.getExceptionVariable() != catchClause.getExceptionVariable()) {
|
if (statement.getExceptionVariable() != catchClause.getExceptionVariable()) {
|
||||||
writer.append(variableName(catchClause.getExceptionVariable())).ws().append("=").ws()
|
if (catchClause.getExceptionVariable() != null) {
|
||||||
.append(var).append(";").softNewLine();
|
writer.append(variableName(catchClause.getExceptionVariable())).ws().append("=").ws()
|
||||||
|
.append("$e;").softNewLine();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
for (Statement part : statement.getHandler()) {
|
for (Statement part : statement.getHandler()) {
|
||||||
part.acceptVisitor(this);
|
part.acceptVisitor(this);
|
||||||
|
@ -1281,7 +1282,7 @@ public class Renderer implements ExprVisitor, StatementVisitor {
|
||||||
writer.outdent().append("}").ws().append("else ");
|
writer.outdent().append("}").ws().append("else ");
|
||||||
}
|
}
|
||||||
writer.append("{").indent().softNewLine();
|
writer.append("{").indent().softNewLine();
|
||||||
writer.append("throw ").append(var).append(";").softNewLine();
|
writer.append("throw $e;").softNewLine();
|
||||||
writer.outdent().append("}").softNewLine();
|
writer.outdent().append("}").softNewLine();
|
||||||
writer.outdent().append("}").softNewLine();
|
writer.outdent().append("}").softNewLine();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
|
|
|
@ -224,5 +224,12 @@ class UnusedVariableEliminator implements ExprVisitor, StatementVisitor {
|
||||||
for (Statement part : statement.getHandler()) {
|
for (Statement part : statement.getHandler()) {
|
||||||
part.acceptVisitor(this);
|
part.acceptVisitor(this);
|
||||||
}
|
}
|
||||||
|
if (statement.getExceptionVariable() != null) {
|
||||||
|
if (variables[statement.getExceptionVariable()] < 0) {
|
||||||
|
statement.setExceptionVariable(null);
|
||||||
|
} else {
|
||||||
|
statement.setExceptionVariable(renumber(statement.getExceptionVariable()));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,7 @@ public class TryCatchStatement extends Statement {
|
||||||
private List<Statement> protectedBody = new ArrayList<>();
|
private List<Statement> protectedBody = new ArrayList<>();
|
||||||
private List<Statement> handler = new ArrayList<>();
|
private List<Statement> handler = new ArrayList<>();
|
||||||
private String exceptionType;
|
private String exceptionType;
|
||||||
private int exceptionVariable;
|
private Integer exceptionVariable;
|
||||||
|
|
||||||
public List<Statement> getProtectedBody() {
|
public List<Statement> getProtectedBody() {
|
||||||
return protectedBody;
|
return protectedBody;
|
||||||
|
@ -44,11 +44,11 @@ public class TryCatchStatement extends Statement {
|
||||||
this.exceptionType = exceptionType;
|
this.exceptionType = exceptionType;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getExceptionVariable() {
|
public Integer getExceptionVariable() {
|
||||||
return exceptionVariable;
|
return exceptionVariable;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setExceptionVariable(int exceptionVariable) {
|
public void setExceptionVariable(Integer exceptionVariable) {
|
||||||
this.exceptionVariable = exceptionVariable;
|
this.exceptionVariable = exceptionVariable;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user