mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2024-12-22 08:14:09 -08:00
Print bytecode listing of a method when decompiler fails to decompile
This commit is contained in:
parent
11d69f15c9
commit
1945e6cb44
|
@ -66,6 +66,7 @@ import org.teavm.model.TryCatchBlock;
|
|||
import org.teavm.model.ValueType;
|
||||
import org.teavm.model.Variable;
|
||||
import org.teavm.model.util.AsyncProgramSplitter;
|
||||
import org.teavm.model.util.ListingBuilder;
|
||||
import org.teavm.model.util.ProgramUtils;
|
||||
|
||||
/**
|
||||
|
@ -260,7 +261,13 @@ public class Decompiler {
|
|||
Program program = method.getProgram();
|
||||
int[] targetBlocks = new int[program.basicBlockCount()];
|
||||
Arrays.fill(targetBlocks, -1);
|
||||
methodNode.setBody(getRegularMethodStatement(program, targetBlocks, false).getStatement());
|
||||
try {
|
||||
methodNode.setBody(getRegularMethodStatement(program, targetBlocks, false).getStatement());
|
||||
} catch (RuntimeException e) {
|
||||
StringBuilder sb = new StringBuilder("Error decompiling method " + method.getReference() + ":\n");
|
||||
sb.append(new ListingBuilder().buildListing(program, " "));
|
||||
throw new DecompilationException(sb.toString(), e);
|
||||
}
|
||||
for (int i = 0; i < program.variableCount(); ++i) {
|
||||
methodNode.getVariables().add(program.variableAt(i).getRegister());
|
||||
}
|
||||
|
@ -311,8 +318,15 @@ public class Decompiler {
|
|||
AsyncProgramSplitter splitter = new AsyncProgramSplitter(classSource, splitMethods);
|
||||
splitter.split(method.getProgram());
|
||||
for (int i = 0; i < splitter.size(); ++i) {
|
||||
AsyncMethodPart part = getRegularMethodStatement(splitter.getProgram(i), splitter.getBlockSuccessors(i),
|
||||
i > 0);
|
||||
AsyncMethodPart part;
|
||||
try {
|
||||
part = getRegularMethodStatement(splitter.getProgram(i), splitter.getBlockSuccessors(i), i > 0);
|
||||
} catch (RuntimeException e) {
|
||||
StringBuilder sb = new StringBuilder("Error decompiling method " + method.getReference() +
|
||||
" part " + i + ":\n");
|
||||
sb.append(new ListingBuilder().buildListing(splitter.getProgram(i), " "));
|
||||
throw new DecompilationException(sb.toString(), e);
|
||||
}
|
||||
node.getBody().add(part);
|
||||
}
|
||||
Program program = method.getProgram();
|
||||
|
|
Loading…
Reference in New Issue
Block a user