Spaces:
Running
Running
let wasm_bindgen; | |
(function() { | |
const __exports = {}; | |
let script_src; | |
if (typeof document !== 'undefined' && document.currentScript !== null) { | |
script_src = new URL(document.currentScript.src, location.href).toString(); | |
} | |
let wasm = undefined; | |
const heap = new Array(128).fill(undefined); | |
heap.push(undefined, null, true, false); | |
function getObject(idx) { return heap[idx]; } | |
let heap_next = heap.length; | |
function dropObject(idx) { | |
if (idx < 132) return; | |
heap[idx] = heap_next; | |
heap_next = idx; | |
} | |
function takeObject(idx) { | |
const ret = getObject(idx); | |
dropObject(idx); | |
return ret; | |
} | |
function addHeapObject(obj) { | |
if (heap_next === heap.length) heap.push(heap.length + 1); | |
const idx = heap_next; | |
heap_next = heap[idx]; | |
heap[idx] = obj; | |
return idx; | |
} | |
function debugString(val) { | |
// primitive types | |
const type = typeof val; | |
if (type == 'number' || type == 'boolean' || val == null) { | |
return `${val}`; | |
} | |
if (type == 'string') { | |
return `"${val}"`; | |
} | |
if (type == 'symbol') { | |
const description = val.description; | |
if (description == null) { | |
return 'Symbol'; | |
} else { | |
return `Symbol(${description})`; | |
} | |
} | |
if (type == 'function') { | |
const name = val.name; | |
if (typeof name == 'string' && name.length > 0) { | |
return `Function(${name})`; | |
} else { | |
return 'Function'; | |
} | |
} | |
// objects | |
if (Array.isArray(val)) { | |
const length = val.length; | |
let debug = '['; | |
if (length > 0) { | |
debug += debugString(val[0]); | |
} | |
for(let i = 1; i < length; i++) { | |
debug += ', ' + debugString(val[i]); | |
} | |
debug += ']'; | |
return debug; | |
} | |
// Test for built-in | |
const builtInMatches = /\[object ([^\]]+)\]/.exec(toString.call(val)); | |
let className; | |
if (builtInMatches.length > 1) { | |
className = builtInMatches[1]; | |
} else { | |
// Failed to match the standard '[object ClassName]' | |
return toString.call(val); | |
} | |
if (className == 'Object') { | |
// we're a user defined class or Object | |
// JSON.stringify avoids problems with cycles, and is generally much | |
// easier than looping through ownProperties of `val`. | |
try { | |
return 'Object(' + JSON.stringify(val) + ')'; | |
} catch (_) { | |
return 'Object'; | |
} | |
} | |
// errors | |
if (val instanceof Error) { | |
return `${val.name}: ${val.message}\n${val.stack}`; | |
} | |
// TODO we could test for more things here, like `Set`s and `Map`s. | |
return className; | |
} | |
let WASM_VECTOR_LEN = 0; | |
let cachedUint8Memory0 = null; | |
function getUint8Memory0() { | |
if (cachedUint8Memory0 === null || cachedUint8Memory0.byteLength === 0) { | |
cachedUint8Memory0 = new Uint8Array(wasm.memory.buffer); | |
} | |
return cachedUint8Memory0; | |
} | |
const cachedTextEncoder = (typeof TextEncoder !== 'undefined' ? new TextEncoder('utf-8') : { encode: () => { throw Error('TextEncoder not available') } } ); | |
const encodeString = (typeof cachedTextEncoder.encodeInto === 'function' | |
? function (arg, view) { | |
return cachedTextEncoder.encodeInto(arg, view); | |
} | |
: function (arg, view) { | |
const buf = cachedTextEncoder.encode(arg); | |
view.set(buf); | |
return { | |
read: arg.length, | |
written: buf.length | |
}; | |
}); | |
function passStringToWasm0(arg, malloc, realloc) { | |
if (realloc === undefined) { | |
const buf = cachedTextEncoder.encode(arg); | |
const ptr = malloc(buf.length, 1) >>> 0; | |
getUint8Memory0().subarray(ptr, ptr + buf.length).set(buf); | |
WASM_VECTOR_LEN = buf.length; | |
return ptr; | |
} | |
let len = arg.length; | |
let ptr = malloc(len, 1) >>> 0; | |
const mem = getUint8Memory0(); | |
let offset = 0; | |
for (; offset < len; offset++) { | |
const code = arg.charCodeAt(offset); | |
if (code > 0x7F) break; | |
mem[ptr + offset] = code; | |
} | |
if (offset !== len) { | |
if (offset !== 0) { | |
arg = arg.slice(offset); | |
} | |
ptr = realloc(ptr, len, len = offset + arg.length * 3, 1) >>> 0; | |
const view = getUint8Memory0().subarray(ptr + offset, ptr + len); | |
const ret = encodeString(arg, view); | |
offset += ret.written; | |
} | |
WASM_VECTOR_LEN = offset; | |
return ptr; | |
} | |
let cachedInt32Memory0 = null; | |
function getInt32Memory0() { | |
if (cachedInt32Memory0 === null || cachedInt32Memory0.byteLength === 0) { | |
cachedInt32Memory0 = new Int32Array(wasm.memory.buffer); | |
} | |
return cachedInt32Memory0; | |
} | |
const cachedTextDecoder = (typeof TextDecoder !== 'undefined' ? new TextDecoder('utf-8', { ignoreBOM: true, fatal: true }) : { decode: () => { throw Error('TextDecoder not available') } } ); | |
if (typeof TextDecoder !== 'undefined') { cachedTextDecoder.decode(); }; | |
function getStringFromWasm0(ptr, len) { | |
ptr = ptr >>> 0; | |
return cachedTextDecoder.decode(getUint8Memory0().subarray(ptr, ptr + len)); | |
} | |
function makeClosure(arg0, arg1, dtor, f) { | |
const state = { a: arg0, b: arg1, cnt: 1, dtor }; | |
const real = (...args) => { | |
// First up with a closure we increment the internal reference | |
// count. This ensures that the Rust closure environment won't | |
// be deallocated while we're invoking it. | |
state.cnt++; | |
try { | |
return f(state.a, state.b, ...args); | |
} finally { | |
if (--state.cnt === 0) { | |
wasm.__wbindgen_export_2.get(state.dtor)(state.a, state.b); | |
state.a = 0; | |
} | |
} | |
}; | |
real.original = state; | |
return real; | |
} | |
function __wbg_adapter_14(arg0, arg1, arg2) { | |
wasm._dyn_core__ops__function__Fn__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h394c66cd6bc0689a(arg0, arg1, addHeapObject(arg2)); | |
} | |
function handleError(f, args) { | |
try { | |
return f.apply(this, args); | |
} catch (e) { | |
wasm.__wbindgen_exn_store(addHeapObject(e)); | |
} | |
} | |
async function __wbg_load(module, imports) { | |
if (typeof Response === 'function' && module instanceof Response) { | |
if (typeof WebAssembly.instantiateStreaming === 'function') { | |
try { | |
return await WebAssembly.instantiateStreaming(module, imports); | |
} catch (e) { | |
if (module.headers.get('Content-Type') != 'application/wasm') { | |
console.warn("`WebAssembly.instantiateStreaming` failed because your server does not serve wasm with `application/wasm` MIME type. Falling back to `WebAssembly.instantiate` which is slower. Original error:\n", e); | |
} else { | |
throw e; | |
} | |
} | |
} | |
const bytes = await module.arrayBuffer(); | |
return await WebAssembly.instantiate(bytes, imports); | |
} else { | |
const instance = await WebAssembly.instantiate(module, imports); | |
if (instance instanceof WebAssembly.Instance) { | |
return { instance, module }; | |
} else { | |
return instance; | |
} | |
} | |
} | |
function __wbg_get_imports() { | |
const imports = {}; | |
imports.wbg = {}; | |
imports.wbg.__wbindgen_object_drop_ref = function(arg0) { | |
takeObject(arg0); | |
}; | |
imports.wbg.__wbg_log_3af90b48c052f90b = function(arg0, arg1) { | |
console.log(getStringFromWasm0(arg0, arg1)); | |
}; | |
imports.wbg.__wbindgen_object_clone_ref = function(arg0) { | |
const ret = getObject(arg0); | |
return addHeapObject(ret); | |
}; | |
imports.wbg.__wbg_new_abda76e883ba8a5f = function() { | |
const ret = new Error(); | |
return addHeapObject(ret); | |
}; | |
imports.wbg.__wbg_stack_658279fe44541cf6 = function(arg0, arg1) { | |
const ret = getObject(arg1).stack; | |
const ptr1 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); | |
const len1 = WASM_VECTOR_LEN; | |
getInt32Memory0()[arg0 / 4 + 1] = len1; | |
getInt32Memory0()[arg0 / 4 + 0] = ptr1; | |
}; | |
imports.wbg.__wbg_error_f851667af71bcfc6 = function(arg0, arg1) { | |
let deferred0_0; | |
let deferred0_1; | |
try { | |
deferred0_0 = arg0; | |
deferred0_1 = arg1; | |
console.error(getStringFromWasm0(arg0, arg1)); | |
} finally { | |
wasm.__wbindgen_free(deferred0_0, deferred0_1, 1); | |
} | |
}; | |
imports.wbg.__wbg_setonmessage_731266b6f3ab0860 = function(arg0, arg1) { | |
getObject(arg0).onmessage = getObject(arg1); | |
}; | |
imports.wbg.__wbg_close_889c0c4e86f1403e = function(arg0) { | |
getObject(arg0).close(); | |
}; | |
imports.wbg.__wbg_postMessage_2f0b8369b84c3c1e = function() { return handleError(function (arg0, arg1) { | |
getObject(arg0).postMessage(getObject(arg1)); | |
}, arguments) }; | |
imports.wbg.__wbg_data_ab99ae4a2e1e8bc9 = function(arg0) { | |
const ret = getObject(arg0).data; | |
return addHeapObject(ret); | |
}; | |
imports.wbg.__wbg_newnoargs_581967eacc0e2604 = function(arg0, arg1) { | |
const ret = new Function(getStringFromWasm0(arg0, arg1)); | |
return addHeapObject(ret); | |
}; | |
imports.wbg.__wbg_call_cb65541d95d71282 = function() { return handleError(function (arg0, arg1) { | |
const ret = getObject(arg0).call(getObject(arg1)); | |
return addHeapObject(ret); | |
}, arguments) }; | |
imports.wbg.__wbg_self_1ff1d729e9aae938 = function() { return handleError(function () { | |
const ret = self.self; | |
return addHeapObject(ret); | |
}, arguments) }; | |
imports.wbg.__wbg_window_5f4faef6c12b79ec = function() { return handleError(function () { | |
const ret = window.window; | |
return addHeapObject(ret); | |
}, arguments) }; | |
imports.wbg.__wbg_globalThis_1d39714405582d3c = function() { return handleError(function () { | |
const ret = globalThis.globalThis; | |
return addHeapObject(ret); | |
}, arguments) }; | |
imports.wbg.__wbg_global_651f05c6a0944d1c = function() { return handleError(function () { | |
const ret = global.global; | |
return addHeapObject(ret); | |
}, arguments) }; | |
imports.wbg.__wbindgen_is_undefined = function(arg0) { | |
const ret = getObject(arg0) === undefined; | |
return ret; | |
}; | |
imports.wbg.__wbg_buffer_085ec1f694018c4f = function(arg0) { | |
const ret = getObject(arg0).buffer; | |
return addHeapObject(ret); | |
}; | |
imports.wbg.__wbg_newwithbyteoffsetandlength_6da8e527659b86aa = function(arg0, arg1, arg2) { | |
const ret = new Uint8Array(getObject(arg0), arg1 >>> 0, arg2 >>> 0); | |
return addHeapObject(ret); | |
}; | |
imports.wbg.__wbg_new_8125e318e6245eed = function(arg0) { | |
const ret = new Uint8Array(getObject(arg0)); | |
return addHeapObject(ret); | |
}; | |
imports.wbg.__wbg_set_5cf90238115182c3 = function(arg0, arg1, arg2) { | |
getObject(arg0).set(getObject(arg1), arg2 >>> 0); | |
}; | |
imports.wbg.__wbg_length_72e2208bbc0efc61 = function(arg0) { | |
const ret = getObject(arg0).length; | |
return ret; | |
}; | |
imports.wbg.__wbindgen_debug_string = function(arg0, arg1) { | |
const ret = debugString(getObject(arg1)); | |
const ptr1 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); | |
const len1 = WASM_VECTOR_LEN; | |
getInt32Memory0()[arg0 / 4 + 1] = len1; | |
getInt32Memory0()[arg0 / 4 + 0] = ptr1; | |
}; | |
imports.wbg.__wbindgen_throw = function(arg0, arg1) { | |
throw new Error(getStringFromWasm0(arg0, arg1)); | |
}; | |
imports.wbg.__wbindgen_memory = function() { | |
const ret = wasm.memory; | |
return addHeapObject(ret); | |
}; | |
imports.wbg.__wbindgen_closure_wrapper73 = function(arg0, arg1, arg2) { | |
const ret = makeClosure(arg0, arg1, 24, __wbg_adapter_14); | |
return addHeapObject(ret); | |
}; | |
return imports; | |
} | |
function __wbg_init_memory(imports, maybe_memory) { | |
} | |
function __wbg_finalize_init(instance, module) { | |
wasm = instance.exports; | |
__wbg_init.__wbindgen_wasm_module = module; | |
cachedInt32Memory0 = null; | |
cachedUint8Memory0 = null; | |
wasm.__wbindgen_start(); | |
return wasm; | |
} | |
function initSync(module) { | |
if (wasm !== undefined) return wasm; | |
const imports = __wbg_get_imports(); | |
__wbg_init_memory(imports); | |
if (!(module instanceof WebAssembly.Module)) { | |
module = new WebAssembly.Module(module); | |
} | |
const instance = new WebAssembly.Instance(module, imports); | |
return __wbg_finalize_init(instance, module); | |
} | |
async function __wbg_init(input) { | |
if (wasm !== undefined) return wasm; | |
if (typeof input === 'undefined' && script_src !== 'undefined') { | |
input = script_src.replace(/\.js$/, '_bg.wasm'); | |
} | |
const imports = __wbg_get_imports(); | |
if (typeof input === 'string' || (typeof Request === 'function' && input instanceof Request) || (typeof URL === 'function' && input instanceof URL)) { | |
input = fetch(input); | |
} | |
__wbg_init_memory(imports); | |
const { instance, module } = await __wbg_load(await input, imports); | |
return __wbg_finalize_init(instance, module); | |
} | |
wasm_bindgen = Object.assign(__wbg_init, { initSync }, __exports); | |
})(); | |