Allow wasm to work without Ooui

This commit is contained in:
Frank A. Krueger 2018-03-13 16:44:06 -07:00
parent b615e7d6d7
commit 9a930deda9
No known key found for this signature in database
GPG Key ID: 0471C67474FFE664
1 changed files with 22 additions and 21 deletions

View File

@ -422,12 +422,13 @@ var WebAssemblyApp = {
runApp: function (a, b) { runApp: function (a, b) {
try { try {
var sessionId = "main"; var sessionId = "main";
var rres = MonoRuntime.call_method (this.main_method, null, [MonoRuntime.mono_string (a), MonoRuntime.mono_string (b)]); MonoRuntime.call_method (this.main_method, null, [MonoRuntime.mono_string (a), MonoRuntime.mono_string (b)]);
var res = MonoRuntime.conv_string (rres);
wasmSession = sessionId; wasmSession = sessionId;
var initialSize = getSize (); if (!!ooui_StartWebAssemblySession_method) {
MonoRuntime.call_method (this.ooui_StartWebAssemblySession_method, null, [MonoRuntime.mono_string (sessionId), MonoRuntime.mono_string ("main"), MonoRuntime.mono_string (Math.round(initialSize.width) + " " + Math.round(initialSize.height))]); var initialSize = getSize ();
return res; MonoRuntime.call_method (this.ooui_StartWebAssemblySession_method, null, [MonoRuntime.mono_string (sessionId), MonoRuntime.mono_string ("main"), MonoRuntime.mono_string (Math.round(initialSize.width) + " " + Math.round(initialSize.height))]);
}
return "ok";
} catch (e) { } catch (e) {
return e.msg; return e.msg;
} }
@ -438,22 +439,6 @@ var WebAssemblyApp = {
}, },
findMethods: function () { findMethods: function () {
this.ooui_module = MonoRuntime.assembly_load ("Ooui");
if (!this.ooui_module)
throw "Could not find Ooui.dll";
this.ooui_class = MonoRuntime.find_class (this.ooui_module, "Ooui", "UI");
if (!this.ooui_class)
throw "Could not find UI class in Ooui module";
this.ooui_StartWebAssemblySession_method = MonoRuntime.find_method (this.ooui_class, "StartWebAssemblySession", -1);
if (!this.ooui_StartWebAssemblySession_method)
throw "Could not find StartWebAssemblySession method";
this.ooui_ReceiveWebAssemblySessionMessageJson_method = MonoRuntime.find_method (this.ooui_class, "ReceiveWebAssemblySessionMessageJson", -1);
if (!this.ooui_ReceiveWebAssemblySessionMessageJson_method)
throw "Could not find ReceiveWebAssemblySessionMessageJson method";
this.main_module = MonoRuntime.assembly_load (Module.entryPoint.a); this.main_module = MonoRuntime.assembly_load (Module.entryPoint.a);
if (!this.main_module) if (!this.main_module)
throw "Could not find Main Module " + Module.entryPoint.a + ".dll"; throw "Could not find Main Module " + Module.entryPoint.a + ".dll";
@ -465,6 +450,22 @@ var WebAssemblyApp = {
this.main_method = MonoRuntime.find_method (this.main_class, Module.entryPoint.m, -1) this.main_method = MonoRuntime.find_method (this.main_class, Module.entryPoint.m, -1)
if (!this.main_method) if (!this.main_method)
throw "Could not find Main method"; throw "Could not find Main method";
this.ooui_module = MonoRuntime.assembly_load ("Ooui");
if (!!this.ooui_module) {
this.ooui_class = MonoRuntime.find_class (this.ooui_module, "Ooui", "UI");
if (!this.ooui_class)
throw "Could not find UI class in Ooui module";
this.ooui_StartWebAssemblySession_method = MonoRuntime.find_method (this.ooui_class, "StartWebAssemblySession", -1);
if (!this.ooui_StartWebAssemblySession_method)
throw "Could not find StartWebAssemblySession method";
this.ooui_ReceiveWebAssemblySessionMessageJson_method = MonoRuntime.find_method (this.ooui_class, "ReceiveWebAssemblySessionMessageJson", -1);
if (!this.ooui_ReceiveWebAssemblySessionMessageJson_method)
throw "Could not find ReceiveWebAssemblySessionMessageJson method";
}
}, },
}; };