我正在尝试按照教程在Webworker中运行emscripten构建的Web组件。
当我实例化模块时,我会得到WebAssembly Instantiation: Import #9 module="global" error: module is not an object or function
。
这是我的代码产生工人并将其发送为编译的模块:
var g_worker = new Worker('worker.js');
WebAssembly.compileStreaming(fetch('my_module.wasm'))
.then(module => {
g_worker.postMessage(module);
});
worker.js:
self.onmessage = function (evt) {
var module = evt.data;
var config = {
env: {
memoryBase: 0,
tableBase: 0,
memory: new WebAssembly.Memory({initial: 256}),
table: new WebAssembly.Table({initial: 0, element: 'anyfunc'})
},
imports: {
imported_func: function(arg) {
console.log(arg);
}
}
};
WebAssembly.instantiate(module, config);
}
我用这些标志构建我的模块:
-I include
-I third_party/eigen-git-mirror
-s EXPORTED_FUNCTIONS="['_my_function', '_malloc', '_free']"
-s EXPORT_NAME="'MyModule'"
-s NO_FILESYSTEM=1
-s MODULARIZE=1
-s EXTRA_EXPORTED_RUNTIME_METHODS='["ccall", "cwrap"]'
-s BUILD_AS_WORKER=1
--memory-init-file 0
-s WASM=1
-s NO_EXIT_RUNTIME=1
-s ALLOW_MEMORY_GROWTH=1
-s TOTAL_MEMORY=256MB
--closure 1
-g3
如果我将 global: {},
添加到 config
字典中,它会抱怨 Import #11 module="global.Math" error: module is not an object or function
,如果然后添加 'global.Math: Math
,我会得到 memory import 0 is smaller than initial 4096, got 256
,依此类推,直到我觉得自己被鼠着。
我怀疑我做错了。
我想我已经弄清楚了。如果我从头开始并将var g_worker = new Worker('worker.js')
放在我的第一个文件中,以及在worker.js中:
self.importScripts('my_module.js');
它有效。似乎我只是读了错误的教程。