mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-24 07:14:50 -08:00
Fix converting method to state machine in some cases. Fix #366
This commit is contained in:
parent
a3dfc0c486
commit
b018e61615
|
@ -40,6 +40,7 @@ import org.teavm.model.TryCatchBlock;
|
||||||
import org.teavm.model.ValueType;
|
import org.teavm.model.ValueType;
|
||||||
import org.teavm.model.Variable;
|
import org.teavm.model.Variable;
|
||||||
import org.teavm.model.instructions.InitClassInstruction;
|
import org.teavm.model.instructions.InitClassInstruction;
|
||||||
|
import org.teavm.model.instructions.InvocationType;
|
||||||
import org.teavm.model.instructions.InvokeInstruction;
|
import org.teavm.model.instructions.InvokeInstruction;
|
||||||
import org.teavm.model.instructions.JumpInstruction;
|
import org.teavm.model.instructions.JumpInstruction;
|
||||||
import org.teavm.model.instructions.MonitorEnterInstruction;
|
import org.teavm.model.instructions.MonitorEnterInstruction;
|
||||||
|
@ -82,9 +83,15 @@ public class AsyncProgramSplitter {
|
||||||
for (Instruction insn : sourceBlock) {
|
for (Instruction insn : sourceBlock) {
|
||||||
if (insn instanceof InvokeInstruction) {
|
if (insn instanceof InvokeInstruction) {
|
||||||
InvokeInstruction invoke = (InvokeInstruction) insn;
|
InvokeInstruction invoke = (InvokeInstruction) insn;
|
||||||
|
if (invoke.getType() == InvocationType.VIRTUAL) {
|
||||||
|
if (!isAsyncMethod(findRealMethod(invoke.getMethod()))) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
if (!asyncMethods.contains(findRealMethod(invoke.getMethod()))) {
|
if (!asyncMethods.contains(findRealMethod(invoke.getMethod()))) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
} else if (insn instanceof InitClassInstruction) {
|
} else if (insn instanceof InitClassInstruction) {
|
||||||
if (!isSplittingClassInitializer(((InitClassInstruction) insn).getClassName())) {
|
if (!isSplittingClassInitializer(((InitClassInstruction) insn).getClassName())) {
|
||||||
continue;
|
continue;
|
||||||
|
@ -227,6 +234,33 @@ public class AsyncProgramSplitter {
|
||||||
return method;
|
return method;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean isAsyncMethod(MethodReference method) {
|
||||||
|
if (asyncMethods.isEmpty()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (asyncMethods.contains(method)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
ClassReader cls = classSource.get(method.getClassName());
|
||||||
|
if (cls == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cls.getParent() != null) {
|
||||||
|
if (isAsyncMethod(new MethodReference(cls.getParent(), method.getDescriptor()))) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (String itf : cls.getInterfaces()) {
|
||||||
|
if (isAsyncMethod(new MethodReference(itf, method.getDescriptor()))) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
private Program createStubCopy(Program program) {
|
private Program createStubCopy(Program program) {
|
||||||
Program copy = new Program();
|
Program copy = new Program();
|
||||||
for (int i = 0; i < program.basicBlockCount(); ++i) {
|
for (int i = 0; i < program.basicBlockCount(); ++i) {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user