mirror of
https://github.com/godotengine/godot.git
synced 2024-12-13 06:34:17 +00:00
[HTML5] Fix Mono builds (old emcc?)
Promise chaining the emscripten module `then` function breaks it badly,
causing an infinite loop.
I'm unsure about the source of the issue, but most likely at this point
is due to the old emscripten version (I remember very old html5 builds
having issue with promise chaining too).
With this commit, we no longer use the module as a promise, and
instantiate it using `Promise` objects directly for compatibility.
(cherry picked from commit ae3c9345cc
)
This commit is contained in:
parent
2bf0b2996a
commit
b402c1cb17
@ -101,19 +101,23 @@ const Engine = (function () {
|
|||||||
}
|
}
|
||||||
const me = this;
|
const me = this;
|
||||||
function doInit(promise) {
|
function doInit(promise) {
|
||||||
return promise.then(function (response) {
|
// Care! Promise chaining is bogus with old emscripten versions.
|
||||||
return Godot(me.config.getModuleConfig(loadPath, new Response(response.clone().body, { 'headers': [['content-type', 'application/wasm']] })));
|
// This caused a regression with the Mono build (which uses an older emscripten version).
|
||||||
}).then(function (module) {
|
// Make sure to test that when refactoring.
|
||||||
|
return new Promise(function (resolve, reject) {
|
||||||
|
promise.then(function (response) {
|
||||||
|
const cloned = new Response(response.clone().body, { 'headers': [['content-type', 'application/wasm']] });
|
||||||
|
Godot(me.config.getModuleConfig(loadPath, cloned)).then(function (module) {
|
||||||
const paths = me.config.persistentPaths;
|
const paths = me.config.persistentPaths;
|
||||||
return module['initFS'](paths).then(function (err) {
|
module['initFS'](paths).then(function (err) {
|
||||||
return Promise.resolve(module);
|
|
||||||
});
|
|
||||||
}).then(function (module) {
|
|
||||||
me.rtenv = module;
|
me.rtenv = module;
|
||||||
if (me.config.unloadAfterInit) {
|
if (me.config.unloadAfterInit) {
|
||||||
Engine.unload();
|
Engine.unload();
|
||||||
}
|
}
|
||||||
return Promise.resolve();
|
resolve();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
preloader.setProgressFunc(this.config.onProgress);
|
preloader.setProgressFunc(this.config.onProgress);
|
||||||
|
Loading…
Reference in New Issue
Block a user