UNPKG

nextpnr-viewer

Version:

A HTML 5 Canvas based viewer for nextpnr place and route visualizations.

876 lines (820 loc) 32 kB
let wasm; 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; } let WASM_VECTOR_LEN = 0; let cachedUint8ArrayMemory0 = null; function getUint8ArrayMemory0() { if (cachedUint8ArrayMemory0 === null || cachedUint8ArrayMemory0.byteLength === 0) { cachedUint8ArrayMemory0 = new Uint8Array(wasm.memory.buffer); } return cachedUint8ArrayMemory0; } 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; getUint8ArrayMemory0().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 = getUint8ArrayMemory0(); 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 = getUint8ArrayMemory0().subarray(ptr + offset, ptr + len); const ret = encodeString(arg, view); offset += ret.written; ptr = realloc(ptr, len, offset, 1) >>> 0; } WASM_VECTOR_LEN = offset; return ptr; } function isLikeNone(x) { return x === undefined || x === null; } let cachedDataViewMemory0 = null; function getDataViewMemory0() { if (cachedDataViewMemory0 === null || cachedDataViewMemory0.buffer.detached === true || (cachedDataViewMemory0.buffer.detached === undefined && cachedDataViewMemory0.buffer !== wasm.memory.buffer)) { cachedDataViewMemory0 = new DataView(wasm.memory.buffer); } return cachedDataViewMemory0; } 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(getUint8ArrayMemory0().subarray(ptr, ptr + len)); } 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; } function passArray8ToWasm0(arg, malloc) { const ptr = malloc(arg.length * 1, 1) >>> 0; getUint8ArrayMemory0().set(arg, ptr / 1); WASM_VECTOR_LEN = arg.length; return ptr; } function handleError(f, args) { try { return f.apply(this, args); } catch (e) { wasm.__wbindgen_exn_store(addHeapObject(e)); } } const ViewerECP5Finalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_viewerecp5_free(ptr >>> 0, 1)); class ViewerECP5 { __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; ViewerECP5Finalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_viewerecp5_free(ptr, 0); } /** * @param {HTMLCanvasElement} canvas * @param {Uint8Array} chipdata * @param {ColorConfig} colors * @param {CellColorConfig} cell_colors */ constructor(canvas, chipdata, colors, cell_colors) { try { const retptr = wasm.__wbindgen_add_to_stack_pointer(-16); const ptr0 = passArray8ToWasm0(chipdata, wasm.__wbindgen_malloc); const len0 = WASM_VECTOR_LEN; wasm.viewerecp5_new(retptr, addHeapObject(canvas), ptr0, len0, addHeapObject(colors), addHeapObject(cell_colors)); var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true); var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true); var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true); if (r2) { throw takeObject(r1); } this.__wbg_ptr = r0 >>> 0; ViewerECP5Finalization.register(this, this.__wbg_ptr, this); return this; } finally { wasm.__wbindgen_add_to_stack_pointer(16); } } /** * @param {boolean | undefined} [force_first] */ render(force_first) { try { const retptr = wasm.__wbindgen_add_to_stack_pointer(-16); wasm.viewerecp5_render(retptr, this.__wbg_ptr, isLikeNone(force_first) ? 0xFFFFFF : force_first ? 1 : 0); var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true); var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true); if (r1) { throw takeObject(r0); } } finally { wasm.__wbindgen_add_to_stack_pointer(16); } } /** * @param {NextpnrJson} obj */ show_json(obj) { try { const retptr = wasm.__wbindgen_add_to_stack_pointer(-16); wasm.viewerecp5_show_json(retptr, this.__wbg_ptr, addHeapObject(obj)); var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true); var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true); if (r1) { throw takeObject(r0); } } finally { wasm.__wbindgen_add_to_stack_pointer(16); } } /** * @param {number} amt * @param {number} x * @param {number} y */ zoom(amt, x, y) { try { const retptr = wasm.__wbindgen_add_to_stack_pointer(-16); wasm.viewerecp5_zoom(retptr, this.__wbg_ptr, amt, x, y); var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true); var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true); if (r1) { throw takeObject(r0); } } finally { wasm.__wbindgen_add_to_stack_pointer(16); } } /** * @param {number} x * @param {number} y */ pan(x, y) { try { const retptr = wasm.__wbindgen_add_to_stack_pointer(-16); wasm.viewerecp5_pan(retptr, this.__wbg_ptr, x, y); var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true); var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true); if (r1) { throw takeObject(r0); } } finally { wasm.__wbindgen_add_to_stack_pointer(16); } } } 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.__wbindgen_string_get = function(arg0, arg1) { const obj = getObject(arg1); const ret = typeof(obj) === 'string' ? obj : undefined; var ptr1 = isLikeNone(ret) ? 0 : passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); var len1 = WASM_VECTOR_LEN; getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true); getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true); }; imports.wbg.__wbindgen_is_object = function(arg0) { const val = getObject(arg0); const ret = typeof(val) === 'object' && val !== null; return ret; }; imports.wbg.__wbindgen_is_undefined = function(arg0) { const ret = getObject(arg0) === undefined; return ret; }; imports.wbg.__wbindgen_in = function(arg0, arg1) { const ret = getObject(arg0) in getObject(arg1); return ret; }; imports.wbg.__wbindgen_error_new = function(arg0, arg1) { const ret = new Error(getStringFromWasm0(arg0, arg1)); return addHeapObject(ret); }; imports.wbg.__wbindgen_is_falsy = function(arg0) { const ret = !getObject(arg0); return 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; getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true); getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true); }; 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.__wbindgen_jsval_loose_eq = function(arg0, arg1) { const ret = getObject(arg0) == getObject(arg1); return ret; }; imports.wbg.__wbindgen_boolean_get = function(arg0) { const v = getObject(arg0); const ret = typeof(v) === 'boolean' ? (v ? 1 : 0) : 2; return ret; }; imports.wbg.__wbindgen_number_get = function(arg0, arg1) { const obj = getObject(arg1); const ret = typeof(obj) === 'number' ? obj : undefined; getDataViewMemory0().setFloat64(arg0 + 8 * 1, isLikeNone(ret) ? 0 : ret, true); getDataViewMemory0().setInt32(arg0 + 4 * 0, !isLikeNone(ret), true); }; imports.wbg.__wbindgen_as_number = function(arg0) { const ret = +getObject(arg0); return ret; }; imports.wbg.__wbg_String_b9412f8799faab3e = function(arg0, arg1) { const ret = String(getObject(arg1)); const ptr1 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len1 = WASM_VECTOR_LEN; getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true); getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true); }; imports.wbg.__wbindgen_object_clone_ref = function(arg0) { const ret = getObject(arg0); return addHeapObject(ret); }; imports.wbg.__wbindgen_string_new = function(arg0, arg1) { const ret = getStringFromWasm0(arg0, arg1); return addHeapObject(ret); }; imports.wbg.__wbg_getwithrefkey_edc2c8960f0f1191 = function(arg0, arg1) { const ret = getObject(arg0)[getObject(arg1)]; return addHeapObject(ret); }; imports.wbg.__wbg_instanceof_WebGl2RenderingContext_8dbe5170d8fdea28 = function(arg0) { let result; try { result = getObject(arg0) instanceof WebGL2RenderingContext; } catch (_) { result = false; } const ret = result; return ret; }; imports.wbg.__wbg_bindVertexArray_9971ca458d8940ea = function(arg0, arg1) { getObject(arg0).bindVertexArray(getObject(arg1)); }; imports.wbg.__wbg_bufferData_97b16c4aedab785a = function(arg0, arg1, arg2, arg3) { getObject(arg0).bufferData(arg1 >>> 0, getObject(arg2), arg3 >>> 0); }; imports.wbg.__wbg_createVertexArray_ec08b54b9f8c74ea = function(arg0) { const ret = getObject(arg0).createVertexArray(); return isLikeNone(ret) ? 0 : addHeapObject(ret); }; imports.wbg.__wbg_attachShader_299671ccaa78592c = function(arg0, arg1, arg2) { getObject(arg0).attachShader(getObject(arg1), getObject(arg2)); }; imports.wbg.__wbg_bindBuffer_70e5a7ef4920142a = function(arg0, arg1, arg2) { getObject(arg0).bindBuffer(arg1 >>> 0, getObject(arg2)); }; imports.wbg.__wbg_clear_678615798766f804 = function(arg0, arg1) { getObject(arg0).clear(arg1 >>> 0); }; imports.wbg.__wbg_clearColor_0af942e0c8c453eb = function(arg0, arg1, arg2, arg3, arg4) { getObject(arg0).clearColor(arg1, arg2, arg3, arg4); }; imports.wbg.__wbg_compileShader_9680f4f1d833586c = function(arg0, arg1) { getObject(arg0).compileShader(getObject(arg1)); }; imports.wbg.__wbg_createBuffer_478457cb9beff1a3 = function(arg0) { const ret = getObject(arg0).createBuffer(); return isLikeNone(ret) ? 0 : addHeapObject(ret); }; imports.wbg.__wbg_createProgram_48b8a105fd0cfb35 = function(arg0) { const ret = getObject(arg0).createProgram(); return isLikeNone(ret) ? 0 : addHeapObject(ret); }; imports.wbg.__wbg_createShader_f956a5ec67a77964 = function(arg0, arg1) { const ret = getObject(arg0).createShader(arg1 >>> 0); return isLikeNone(ret) ? 0 : addHeapObject(ret); }; imports.wbg.__wbg_drawArrays_af53529e509d0c8b = function(arg0, arg1, arg2, arg3) { getObject(arg0).drawArrays(arg1 >>> 0, arg2, arg3); }; imports.wbg.__wbg_drawElements_3789cbf91f57c2f5 = function(arg0, arg1, arg2, arg3, arg4) { getObject(arg0).drawElements(arg1 >>> 0, arg2, arg3 >>> 0, arg4); }; imports.wbg.__wbg_enableVertexAttribArray_08b992ae13fe30a9 = function(arg0, arg1) { getObject(arg0).enableVertexAttribArray(arg1 >>> 0); }; imports.wbg.__wbg_getProgramInfoLog_16c69289b6a9c98e = function(arg0, arg1, arg2) { const ret = getObject(arg1).getProgramInfoLog(getObject(arg2)); var ptr1 = isLikeNone(ret) ? 0 : passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); var len1 = WASM_VECTOR_LEN; getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true); getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true); }; imports.wbg.__wbg_getProgramParameter_4c981ddc3b62dda8 = function(arg0, arg1, arg2) { const ret = getObject(arg0).getProgramParameter(getObject(arg1), arg2 >>> 0); return addHeapObject(ret); }; imports.wbg.__wbg_getShaderInfoLog_afb2baaac4baaff5 = function(arg0, arg1, arg2) { const ret = getObject(arg1).getShaderInfoLog(getObject(arg2)); var ptr1 = isLikeNone(ret) ? 0 : passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); var len1 = WASM_VECTOR_LEN; getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true); getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true); }; imports.wbg.__wbg_getShaderParameter_e21fb00f8255b86b = function(arg0, arg1, arg2) { const ret = getObject(arg0).getShaderParameter(getObject(arg1), arg2 >>> 0); return addHeapObject(ret); }; imports.wbg.__wbg_getUniformLocation_74149153bba4c4cb = function(arg0, arg1, arg2, arg3) { const ret = getObject(arg0).getUniformLocation(getObject(arg1), getStringFromWasm0(arg2, arg3)); return isLikeNone(ret) ? 0 : addHeapObject(ret); }; imports.wbg.__wbg_linkProgram_983c5972b815b0de = function(arg0, arg1) { getObject(arg0).linkProgram(getObject(arg1)); }; imports.wbg.__wbg_shaderSource_c36f18b5114855e7 = function(arg0, arg1, arg2, arg3) { getObject(arg0).shaderSource(getObject(arg1), getStringFromWasm0(arg2, arg3)); }; imports.wbg.__wbg_uniform1f_d2ba9f3d60c3859c = function(arg0, arg1, arg2) { getObject(arg0).uniform1f(getObject(arg1), arg2); }; imports.wbg.__wbg_uniform2f_42bc6b11055323f9 = function(arg0, arg1, arg2, arg3) { getObject(arg0).uniform2f(getObject(arg1), arg2, arg3); }; imports.wbg.__wbg_uniform4f_7e85e8eb9dff7886 = function(arg0, arg1, arg2, arg3, arg4, arg5) { getObject(arg0).uniform4f(getObject(arg1), arg2, arg3, arg4, arg5); }; imports.wbg.__wbg_useProgram_8232847dbf97643a = function(arg0, arg1) { getObject(arg0).useProgram(getObject(arg1)); }; imports.wbg.__wbg_vertexAttribPointer_5865b9c8a995365b = function(arg0, arg1, arg2, arg3, arg4, arg5, arg6) { getObject(arg0).vertexAttribPointer(arg1 >>> 0, arg2, arg3 >>> 0, arg4 !== 0, arg5, arg6); }; imports.wbg.__wbg_viewport_e333f63662d91f3a = function(arg0, arg1, arg2, arg3, arg4) { getObject(arg0).viewport(arg1, arg2, arg3, arg4); }; imports.wbg.__wbg_width_cd62a064492c4489 = function(arg0) { const ret = getObject(arg0).width; return ret; }; imports.wbg.__wbg_height_f9f3ea69baf38ed4 = function(arg0) { const ret = getObject(arg0).height; return ret; }; imports.wbg.__wbg_getContext_bf8985355a4d22ca = function() { return handleError(function (arg0, arg1, arg2) { const ret = getObject(arg0).getContext(getStringFromWasm0(arg1, arg2)); return isLikeNone(ret) ? 0 : addHeapObject(ret); }, arguments) }; imports.wbg.__wbg_get_5419cf6b954aa11d = function(arg0, arg1) { const ret = getObject(arg0)[arg1 >>> 0]; return addHeapObject(ret); }; imports.wbg.__wbg_length_f217bbbf7e8e4df4 = function(arg0) { const ret = getObject(arg0).length; return ret; }; imports.wbg.__wbindgen_is_function = function(arg0) { const ret = typeof(getObject(arg0)) === 'function'; return ret; }; imports.wbg.__wbg_next_13b477da1eaa3897 = function(arg0) { const ret = getObject(arg0).next; return addHeapObject(ret); }; imports.wbg.__wbg_next_b06e115d1b01e10b = function() { return handleError(function (arg0) { const ret = getObject(arg0).next(); return addHeapObject(ret); }, arguments) }; imports.wbg.__wbg_done_983b5ffcaec8c583 = function(arg0) { const ret = getObject(arg0).done; return ret; }; imports.wbg.__wbg_value_2ab8a198c834c26a = function(arg0) { const ret = getObject(arg0).value; return addHeapObject(ret); }; imports.wbg.__wbg_iterator_695d699a44d6234c = function() { const ret = Symbol.iterator; return addHeapObject(ret); }; imports.wbg.__wbg_get_ef828680c64da212 = function() { return handleError(function (arg0, arg1) { const ret = Reflect.get(getObject(arg0), getObject(arg1)); return addHeapObject(ret); }, arguments) }; imports.wbg.__wbg_call_a9ef466721e824f2 = function() { return handleError(function (arg0, arg1) { const ret = getObject(arg0).call(getObject(arg1)); return addHeapObject(ret); }, arguments) }; imports.wbg.__wbg_instanceof_ArrayBuffer_74945570b4a62ec7 = function(arg0) { let result; try { result = getObject(arg0) instanceof ArrayBuffer; } catch (_) { result = false; } const ret = result; return ret; }; imports.wbg.__wbg_isSafeInteger_b9dff570f01a9100 = function(arg0) { const ret = Number.isSafeInteger(getObject(arg0)); return ret; }; imports.wbg.__wbg_entries_c02034de337d3ee2 = function(arg0) { const ret = Object.entries(getObject(arg0)); return addHeapObject(ret); }; imports.wbg.__wbg_buffer_ccaed51a635d8a2d = function(arg0) { const ret = getObject(arg0).buffer; return addHeapObject(ret); }; imports.wbg.__wbg_new_fec2611eb9180f95 = function(arg0) { const ret = new Uint8Array(getObject(arg0)); return addHeapObject(ret); }; imports.wbg.__wbg_set_ec2fcf81bc573fd9 = function(arg0, arg1, arg2) { getObject(arg0).set(getObject(arg1), arg2 >>> 0); }; imports.wbg.__wbg_length_9254c4bd3b9f23c4 = function(arg0) { const ret = getObject(arg0).length; return ret; }; imports.wbg.__wbg_newwithbyteoffsetandlength_5f67057565ba35bf = function(arg0, arg1, arg2) { const ret = new Uint32Array(getObject(arg0), arg1 >>> 0, arg2 >>> 0); return addHeapObject(ret); }; imports.wbg.__wbg_newwithbyteoffsetandlength_fc445c2d308275d0 = function(arg0, arg1, arg2) { const ret = new Float32Array(getObject(arg0), arg1 >>> 0, arg2 >>> 0); return addHeapObject(ret); }; imports.wbg.__wbg_instanceof_Uint8Array_df0761410414ef36 = function(arg0) { let result; try { result = getObject(arg0) instanceof Uint8Array; } catch (_) { result = false; } const ret = result; 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; getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true); getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true); }; 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); }; return imports; } function __wbg_finalize_init(instance, module) { wasm = instance.exports; __wbg_init.__wbindgen_wasm_module = module; cachedDataViewMemory0 = null; cachedUint8ArrayMemory0 = null; wasm.__wbindgen_start(); return wasm; } async function __wbg_init(module_or_path) { if (wasm !== undefined) return wasm; if (typeof module_or_path !== 'undefined') { if (Object.getPrototypeOf(module_or_path) === Object.prototype) { ({module_or_path} = module_or_path); } else { console.warn('using deprecated parameters for the initialization function; pass a single object instead'); } } if (typeof module_or_path === 'undefined') { module_or_path = new URL(new URL('assets/nextpnr_renderer_bg-CSZ5OlnW.wasm', import.meta.url).href, import.meta.url); } const imports = __wbg_get_imports(); if (typeof module_or_path === 'string' || (typeof Request === 'function' && module_or_path instanceof Request) || (typeof URL === 'function' && module_or_path instanceof URL)) { module_or_path = fetch(module_or_path); } const { instance, module } = await __wbg_load(await module_or_path, imports); return __wbg_finalize_init(instance, module); } // **** Auxiliary types **** const SUPPORTED_DEVICES = { ecp5: ['25k', '45k', '85k'], }; const defaultConfig = { width: 1280, height: 720, createToggles: true, colors: { active: '#F8F8F2', inactive: '#6272A4', frame: '#BD93F9', background: '#282A36' }, cellColors: {}, chip: { family: 'ecp5', device: '25k' } }; const CHIP_DBS = { "ecp5": { "25k": new URL(new URL('assets/25k-wxun10lP.bin', import.meta.url).href, import.meta.url), "45k": new URL(new URL('assets/45k-D4dKR13e.bin', import.meta.url).href, import.meta.url), "85k": new URL(new URL('assets/85k-BMTfUINe.bin', import.meta.url).href, import.meta.url), } }; function getChipDbUrl(chip) { const url = (CHIP_DBS[chip.family] ?? {})[chip.device]; if (url === undefined) { throw new Error(`Could not find chip database for ${chip.family}:${chip.device}!`); } return url; } async function getChipDb(url) { let chipdb = await fetch(url).then((resp) => resp.arrayBuffer()); return new Uint8Array(chipdb); } let colCanvas; function fromCssColor(colorStr) { if (!colCanvas) { colCanvas = document.createElement('canvas').getContext('2d'); } if (!colCanvas) throw new Error('Could not create canvas to convert color'); colCanvas.fillStyle = colorStr; const col = colCanvas.fillStyle.replace('#', ''); const rstr = col.slice(0, 2); const gstr = col.slice(2, 4); const bstr = col.slice(4, 6); return { r: parseInt(rstr, 16), g: parseInt(gstr, 16), b: parseInt(bstr, 16) }; } let animFrameId = null; function doInAnimFrame(f) { if (animFrameId != null) window.cancelAnimationFrame(animFrameId); animFrameId = window.requestAnimationFrame(() => { f(); animFrameId = null; }); } const VIEWERS = { 'ecp5': ViewerECP5 }; function getViewer(family) { let viewer = VIEWERS[family]; if (viewer === undefined) { throw new Error(`Could not find suitable viewer for ${family}`); } return viewer; } let initialized = false; async function init() { if (!initialized) { await __wbg_init(); initialized = true; } } // **** External API **** function isSupported(family, device) { const devices = SUPPORTED_DEVICES[family] ?? []; return devices.includes(device); } class NextPNRViewer { constructor(container, config) { this.config = { ...defaultConfig, ...config }; // Separate functions so we can throw an error prematurely instead of in the promise const url = getChipDbUrl(this.config.chip); const viewer = getViewer(this.config.chip.family); const colors = { active: fromCssColor(this.config.colors.active), inactive: fromCssColor(this.config.colors.inactive), frame: fromCssColor(this.config.colors.frame), background: fromCssColor(this.config.colors.background) }; const cellColors = Object.fromEntries(Object.entries(this.config.cellColors).map(([cell, colorStr]) => [cell, fromCssColor(colorStr)])); this.container = container; this.canvas = this._createCanvas(container); this._doResize(this.config.width, this.config.height); this.viewer = Promise.all([ init(), getChipDb(url), ]).then(([_, db]) => new viewer(this.canvas, db, colors, cellColors)); this.viewer.then(() => this._addEventListeners(this.canvas)); } ; async render() { // Explicit call to start rendering, so set force to true await this._doRender(true); } async showJson(json) { json = (typeof json === 'string') ? JSON.parse(json) : json; const viewer = await this.viewer; viewer.show_json(json); } async resize(width, height) { this._doResize(width, height); // First render can be delayed, so set force to false await this._doRender(false); } async _doRender(force) { // The first render is relatively expensive, so it is a good idea to delay it until we really need it. // Setting force to true will immediately trigger this first render, while setting it to false essentially // makes this method a no-op until the first render has occurred. const viewer = await this.viewer; viewer.render(force); } _doResize(width, height) { this.container.style.width = `${width}px`; this.container.style.height = `${height}px`; this.container.style.display = 'flex'; this.container.style.flexDirection = 'column'; this.canvas.style.flexGrow = '1'; this.canvas.width = this.canvas.clientWidth; this.canvas.height = this.canvas.clientHeight; } _createCanvas(container) { const elem = document.createElement('canvas'); container.innerHTML = ''; container.appendChild(elem); return elem; } async _addEventListeners(canvas) { const viewer = await this.viewer; let down = false; let firstEvent = true; let oldx = 0; let oldy = 0; // Zoom canvas.addEventListener('wheel', (e) => { e.preventDefault(); if (e.deltaY === 0) return; doInAnimFrame(() => viewer.zoom(e.deltaY > 0 ? 0.05 : -0.05, e.clientX - canvas.offsetLeft, e.clientY - canvas.offsetTop)); }); // Pan canvas.addEventListener('mousedown', (_) => { down = true; firstEvent = true; }); canvas.addEventListener('mouseup', (_) => { down = false; }); canvas.addEventListener('mousemove', (e) => doInAnimFrame(() => { if (down) { if (!firstEvent) { viewer.pan(e.clientX - oldx, e.clientY - oldy); } firstEvent = false; oldx = e.clientX; oldy = e.clientY; } })); } } export { NextPNRViewer, SUPPORTED_DEVICES, defaultConfig, isSupported };