mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2024-12-31 12:24:10 -08:00
Fix issue with async methods in code server
This commit is contained in:
parent
bb62912bea
commit
ed627459c8
|
@ -28,6 +28,7 @@ import org.teavm.model.ClassReader;
|
|||
import org.teavm.model.ClassReaderSource;
|
||||
import org.teavm.model.FieldReference;
|
||||
import org.teavm.model.MethodDescriptor;
|
||||
import org.teavm.model.MethodReader;
|
||||
import org.teavm.model.MethodReference;
|
||||
import org.teavm.model.ValueType;
|
||||
import org.teavm.vm.RenderingException;
|
||||
|
@ -174,7 +175,8 @@ public class RuntimeRenderer {
|
|||
if (cls == null) {
|
||||
return false;
|
||||
}
|
||||
return cls.getMethod(STRING_INTERN_METHOD) != null;
|
||||
MethodReader method = cls.getMethod(STRING_INTERN_METHOD);
|
||||
return method != null && method.getProgram() != null;
|
||||
}
|
||||
|
||||
private void renderRuntimeObjcls() throws IOException {
|
||||
|
@ -183,7 +185,8 @@ public class RuntimeRenderer {
|
|||
|
||||
private void renderRuntimeThreads() throws IOException {
|
||||
ClassReader threadCls = classSource.get(THREAD_CLASS);
|
||||
boolean threadUsed = threadCls != null && threadCls.getMethod(CURRENT_THREAD_METHOD) != null;
|
||||
MethodReader currentThreadMethod = threadCls != null ? threadCls.getMethod(CURRENT_THREAD_METHOD) : null;
|
||||
boolean threadUsed = currentThreadMethod != null && currentThreadMethod.getProgram() != null;
|
||||
|
||||
writer.append("function $rt_getThread()").ws().append("{").indent().softNewLine();
|
||||
if (threadUsed) {
|
||||
|
@ -212,7 +215,8 @@ public class RuntimeRenderer {
|
|||
|
||||
private void renderCreateStackTraceElement() throws IOException {
|
||||
ClassReader cls = classSource.get(STACK_TRACE_ELEM_INIT.getClassName());
|
||||
boolean supported = cls != null && cls.getMethod(STACK_TRACE_ELEM_INIT.getDescriptor()) != null;
|
||||
MethodReader stackTraceElemInit = cls != null ? cls.getMethod(STACK_TRACE_ELEM_INIT.getDescriptor()) : null;
|
||||
boolean supported = stackTraceElemInit != null && stackTraceElemInit.getProgram() != null;
|
||||
|
||||
writer.append("function $rt_createStackElement(")
|
||||
.append("className,").ws()
|
||||
|
@ -235,7 +239,8 @@ public class RuntimeRenderer {
|
|||
|
||||
private void renderSetStackTrace() throws IOException {
|
||||
ClassReader cls = classSource.get(SET_STACK_TRACE_METHOD.getClassName());
|
||||
boolean supported = cls != null && cls.getMethod(SET_STACK_TRACE_METHOD.getDescriptor()) != null;
|
||||
MethodReader setStackTrace = cls != null ? cls.getMethod(SET_STACK_TRACE_METHOD.getDescriptor()) : null;
|
||||
boolean supported = setStackTrace != null && setStackTrace.getProgram() != null;
|
||||
|
||||
writer.append("function $rt_setStack(e,").ws().append("stack)").ws().append("{").indent().softNewLine();
|
||||
if (supported) {
|
||||
|
|
|
@ -46,10 +46,9 @@ public class Linker {
|
|||
for (MethodHolder method : cls.getMethods().toArray(new MethodHolder[0])) {
|
||||
MethodReference methodRef = method.getReference();
|
||||
MethodDependencyInfo methodDep = dependency.getMethod(methodRef);
|
||||
if (methodDep == null) {
|
||||
cls.removeMethod(method);
|
||||
} else if (!methodDep.isUsed()) {
|
||||
if (methodDep == null || !methodDep.isUsed()) {
|
||||
method.getModifiers().add(ElementModifier.ABSTRACT);
|
||||
method.getModifiers().remove(ElementModifier.NATIVE);
|
||||
method.setProgram(null);
|
||||
} else if (method.getProgram() != null) {
|
||||
link(method.getReference(), method.getProgram());
|
||||
|
|
|
@ -271,7 +271,7 @@ public class AsyncMethodFinder {
|
|||
}
|
||||
}
|
||||
|
||||
class AsyncInstructionReader extends AbstractInstructionReader {
|
||||
static class AsyncInstructionReader extends AbstractInstructionReader {
|
||||
boolean async;
|
||||
|
||||
@Override
|
||||
|
|
|
@ -962,10 +962,9 @@ public class TeaVM implements TeaVMHost, ServiceRepository {
|
|||
|
||||
for (MethodHolder method : cls.getMethods().toArray(new MethodHolder[0])) {
|
||||
MethodDependencyInfo methodDep = dependencyAnalyzer.getMethod(method.getReference());
|
||||
if (methodDep == null) {
|
||||
cls.removeMethod(method);
|
||||
} else if (!methodDep.isUsed()) {
|
||||
if (methodDep == null || !methodDep.isUsed()) {
|
||||
method.getModifiers().add(ElementModifier.ABSTRACT);
|
||||
method.getModifiers().remove(ElementModifier.NATIVE);
|
||||
method.setProgram(null);
|
||||
} else {
|
||||
MethodReader methodReader = classReader.getMethod(method.getDescriptor());
|
||||
|
|
|
@ -151,7 +151,7 @@ public class CodeServlet extends HttpServlet {
|
|||
|
||||
public CodeServlet(String mainClass, String[] classPath) {
|
||||
this.mainClass = mainClass;
|
||||
this.classPath = classPath.clone();
|
||||
this.classPath = classSource != null ? classPath.clone() : new String[0];
|
||||
|
||||
httpClient = new HttpClient();
|
||||
httpClient.setFollowRedirects(false);
|
||||
|
|
Loading…
Reference in New Issue
Block a user