@keymanapp/kmc-kmn 17.0.112-alpha → 17.0.113-alpha
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/src/compiler/compiler.d.ts +10 -0
- package/build/src/compiler/compiler.d.ts.map +1 -1
- package/build/src/compiler/compiler.js +74 -23
- package/build/src/compiler/compiler.js.map +1 -1
- package/build/src/import/kmcmplib/wasm-host.js +686 -5
- package/build/src/import/kmcmplib/wasm-host.js.map +1 -1
- package/build/src/import/kmcmplib/wasm-host.wasm +0 -0
- package/package.json +3 -3
|
@@ -288,7 +288,7 @@ var Module = (() => {
|
|
|
288
288
|
} instantiateAsync(wasmBinary, wasmBinaryFile, info, receiveInstantiationResult).catch(readyPromiseReject); return {}; }
|
|
289
289
|
var tempDouble;
|
|
290
290
|
var tempI64;
|
|
291
|
-
var ASM_CONSTS = {
|
|
291
|
+
var ASM_CONSTS = { 74873: $0 => { let path = Module.UTF8ToString($0); const isWin32Path = path.match(/^[a-zA-Z]:/); let root = "/nodefs-mount"; if (!FS.analyzePath(root).exists) {
|
|
292
292
|
FS.mkdir(root);
|
|
293
293
|
if (!isWin32Path) {
|
|
294
294
|
FS.mount(NODEFS, { root: "/" }, root);
|
|
@@ -1614,6 +1614,676 @@ var Module = (() => {
|
|
|
1614
1614
|
throw e;
|
|
1615
1615
|
return -e.errno;
|
|
1616
1616
|
} }
|
|
1617
|
+
function __embind_register_bigint(primitiveType, name, size, minRange, maxRange) { }
|
|
1618
|
+
function getShiftFromSize(size) { switch (size) {
|
|
1619
|
+
case 1: return 0;
|
|
1620
|
+
case 2: return 1;
|
|
1621
|
+
case 4: return 2;
|
|
1622
|
+
case 8: return 3;
|
|
1623
|
+
default: throw new TypeError("Unknown type size: " + size);
|
|
1624
|
+
} }
|
|
1625
|
+
function embind_init_charCodes() { var codes = new Array(256); for (var i = 0; i < 256; ++i) {
|
|
1626
|
+
codes[i] = String.fromCharCode(i);
|
|
1627
|
+
} embind_charCodes = codes; }
|
|
1628
|
+
var embind_charCodes = undefined;
|
|
1629
|
+
function readLatin1String(ptr) { var ret = ""; var c = ptr; while (HEAPU8[c]) {
|
|
1630
|
+
ret += embind_charCodes[HEAPU8[c++]];
|
|
1631
|
+
} return ret; }
|
|
1632
|
+
var awaitingDependencies = {};
|
|
1633
|
+
var registeredTypes = {};
|
|
1634
|
+
var typeDependencies = {};
|
|
1635
|
+
var char_0 = 48;
|
|
1636
|
+
var char_9 = 57;
|
|
1637
|
+
function makeLegalFunctionName(name) { if (undefined === name) {
|
|
1638
|
+
return "_unknown";
|
|
1639
|
+
} name = name.replace(/[^a-zA-Z0-9_]/g, "$"); var f = name.charCodeAt(0); if (f >= char_0 && f <= char_9) {
|
|
1640
|
+
return "_" + name;
|
|
1641
|
+
} return name; }
|
|
1642
|
+
function createNamedFunction(name, body) { name = makeLegalFunctionName(name); return { [name]: function () { return body.apply(this, arguments); } }[name]; }
|
|
1643
|
+
function extendError(baseErrorType, errorName) { var errorClass = createNamedFunction(errorName, function (message) { this.name = errorName; this.message = message; var stack = new Error(message).stack; if (stack !== undefined) {
|
|
1644
|
+
this.stack = this.toString() + "\n" + stack.replace(/^Error(:[^\n]*)?\n/, "");
|
|
1645
|
+
} }); errorClass.prototype = Object.create(baseErrorType.prototype); errorClass.prototype.constructor = errorClass; errorClass.prototype.toString = function () { if (this.message === undefined) {
|
|
1646
|
+
return this.name;
|
|
1647
|
+
}
|
|
1648
|
+
else {
|
|
1649
|
+
return this.name + ": " + this.message;
|
|
1650
|
+
} }; return errorClass; }
|
|
1651
|
+
var BindingError = undefined;
|
|
1652
|
+
function throwBindingError(message) { throw new BindingError(message); }
|
|
1653
|
+
var InternalError = undefined;
|
|
1654
|
+
function throwInternalError(message) { throw new InternalError(message); }
|
|
1655
|
+
function whenDependentTypesAreResolved(myTypes, dependentTypes, getTypeConverters) { myTypes.forEach(function (type) { typeDependencies[type] = dependentTypes; }); function onComplete(typeConverters) { var myTypeConverters = getTypeConverters(typeConverters); if (myTypeConverters.length !== myTypes.length) {
|
|
1656
|
+
throwInternalError("Mismatched type converter count");
|
|
1657
|
+
} for (var i = 0; i < myTypes.length; ++i) {
|
|
1658
|
+
registerType(myTypes[i], myTypeConverters[i]);
|
|
1659
|
+
} } var typeConverters = new Array(dependentTypes.length); var unregisteredTypes = []; var registered = 0; dependentTypes.forEach((dt, i) => { if (registeredTypes.hasOwnProperty(dt)) {
|
|
1660
|
+
typeConverters[i] = registeredTypes[dt];
|
|
1661
|
+
}
|
|
1662
|
+
else {
|
|
1663
|
+
unregisteredTypes.push(dt);
|
|
1664
|
+
if (!awaitingDependencies.hasOwnProperty(dt)) {
|
|
1665
|
+
awaitingDependencies[dt] = [];
|
|
1666
|
+
}
|
|
1667
|
+
awaitingDependencies[dt].push(() => { typeConverters[i] = registeredTypes[dt]; ++registered; if (registered === unregisteredTypes.length) {
|
|
1668
|
+
onComplete(typeConverters);
|
|
1669
|
+
} });
|
|
1670
|
+
} }); if (0 === unregisteredTypes.length) {
|
|
1671
|
+
onComplete(typeConverters);
|
|
1672
|
+
} }
|
|
1673
|
+
function registerType(rawType, registeredInstance, options = {}) { if (!("argPackAdvance" in registeredInstance)) {
|
|
1674
|
+
throw new TypeError("registerType registeredInstance requires argPackAdvance");
|
|
1675
|
+
} var name = registeredInstance.name; if (!rawType) {
|
|
1676
|
+
throwBindingError('type "' + name + '" must have a positive integer typeid pointer');
|
|
1677
|
+
} if (registeredTypes.hasOwnProperty(rawType)) {
|
|
1678
|
+
if (options.ignoreDuplicateRegistrations) {
|
|
1679
|
+
return;
|
|
1680
|
+
}
|
|
1681
|
+
else {
|
|
1682
|
+
throwBindingError("Cannot register type '" + name + "' twice");
|
|
1683
|
+
}
|
|
1684
|
+
} registeredTypes[rawType] = registeredInstance; delete typeDependencies[rawType]; if (awaitingDependencies.hasOwnProperty(rawType)) {
|
|
1685
|
+
var callbacks = awaitingDependencies[rawType];
|
|
1686
|
+
delete awaitingDependencies[rawType];
|
|
1687
|
+
callbacks.forEach(cb => cb());
|
|
1688
|
+
} }
|
|
1689
|
+
function __embind_register_bool(rawType, name, size, trueValue, falseValue) { var shift = getShiftFromSize(size); name = readLatin1String(name); registerType(rawType, { name: name, "fromWireType": function (wt) { return !!wt; }, "toWireType": function (destructors, o) { return o ? trueValue : falseValue; }, "argPackAdvance": 8, "readValueFromPointer": function (pointer) { var heap; if (size === 1) {
|
|
1690
|
+
heap = HEAP8;
|
|
1691
|
+
}
|
|
1692
|
+
else if (size === 2) {
|
|
1693
|
+
heap = HEAP16;
|
|
1694
|
+
}
|
|
1695
|
+
else if (size === 4) {
|
|
1696
|
+
heap = HEAP32;
|
|
1697
|
+
}
|
|
1698
|
+
else {
|
|
1699
|
+
throw new TypeError("Unknown boolean type size: " + name);
|
|
1700
|
+
} return this["fromWireType"](heap[pointer >> shift]); }, destructorFunction: null }); }
|
|
1701
|
+
function ClassHandle_isAliasOf(other) { if (!(this instanceof ClassHandle)) {
|
|
1702
|
+
return false;
|
|
1703
|
+
} if (!(other instanceof ClassHandle)) {
|
|
1704
|
+
return false;
|
|
1705
|
+
} var leftClass = this.$$.ptrType.registeredClass; var left = this.$$.ptr; var rightClass = other.$$.ptrType.registeredClass; var right = other.$$.ptr; while (leftClass.baseClass) {
|
|
1706
|
+
left = leftClass.upcast(left);
|
|
1707
|
+
leftClass = leftClass.baseClass;
|
|
1708
|
+
} while (rightClass.baseClass) {
|
|
1709
|
+
right = rightClass.upcast(right);
|
|
1710
|
+
rightClass = rightClass.baseClass;
|
|
1711
|
+
} return leftClass === rightClass && left === right; }
|
|
1712
|
+
function shallowCopyInternalPointer(o) { return { count: o.count, deleteScheduled: o.deleteScheduled, preservePointerOnDelete: o.preservePointerOnDelete, ptr: o.ptr, ptrType: o.ptrType, smartPtr: o.smartPtr, smartPtrType: o.smartPtrType }; }
|
|
1713
|
+
function throwInstanceAlreadyDeleted(obj) { function getInstanceTypeName(handle) { return handle.$$.ptrType.registeredClass.name; } throwBindingError(getInstanceTypeName(obj) + " instance already deleted"); }
|
|
1714
|
+
var finalizationRegistry = false;
|
|
1715
|
+
function detachFinalizer(handle) { }
|
|
1716
|
+
function runDestructor($$) { if ($$.smartPtr) {
|
|
1717
|
+
$$.smartPtrType.rawDestructor($$.smartPtr);
|
|
1718
|
+
}
|
|
1719
|
+
else {
|
|
1720
|
+
$$.ptrType.registeredClass.rawDestructor($$.ptr);
|
|
1721
|
+
} }
|
|
1722
|
+
function releaseClassHandle($$) { $$.count.value -= 1; var toDelete = 0 === $$.count.value; if (toDelete) {
|
|
1723
|
+
runDestructor($$);
|
|
1724
|
+
} }
|
|
1725
|
+
function downcastPointer(ptr, ptrClass, desiredClass) { if (ptrClass === desiredClass) {
|
|
1726
|
+
return ptr;
|
|
1727
|
+
} if (undefined === desiredClass.baseClass) {
|
|
1728
|
+
return null;
|
|
1729
|
+
} var rv = downcastPointer(ptr, ptrClass, desiredClass.baseClass); if (rv === null) {
|
|
1730
|
+
return null;
|
|
1731
|
+
} return desiredClass.downcast(rv); }
|
|
1732
|
+
var registeredPointers = {};
|
|
1733
|
+
function getInheritedInstanceCount() { return Object.keys(registeredInstances).length; }
|
|
1734
|
+
function getLiveInheritedInstances() { var rv = []; for (var k in registeredInstances) {
|
|
1735
|
+
if (registeredInstances.hasOwnProperty(k)) {
|
|
1736
|
+
rv.push(registeredInstances[k]);
|
|
1737
|
+
}
|
|
1738
|
+
} return rv; }
|
|
1739
|
+
var deletionQueue = [];
|
|
1740
|
+
function flushPendingDeletes() { while (deletionQueue.length) {
|
|
1741
|
+
var obj = deletionQueue.pop();
|
|
1742
|
+
obj.$$.deleteScheduled = false;
|
|
1743
|
+
obj["delete"]();
|
|
1744
|
+
} }
|
|
1745
|
+
var delayFunction = undefined;
|
|
1746
|
+
function setDelayFunction(fn) { delayFunction = fn; if (deletionQueue.length && delayFunction) {
|
|
1747
|
+
delayFunction(flushPendingDeletes);
|
|
1748
|
+
} }
|
|
1749
|
+
function init_embind() { Module["getInheritedInstanceCount"] = getInheritedInstanceCount; Module["getLiveInheritedInstances"] = getLiveInheritedInstances; Module["flushPendingDeletes"] = flushPendingDeletes; Module["setDelayFunction"] = setDelayFunction; }
|
|
1750
|
+
var registeredInstances = {};
|
|
1751
|
+
function getBasestPointer(class_, ptr) { if (ptr === undefined) {
|
|
1752
|
+
throwBindingError("ptr should not be undefined");
|
|
1753
|
+
} while (class_.baseClass) {
|
|
1754
|
+
ptr = class_.upcast(ptr);
|
|
1755
|
+
class_ = class_.baseClass;
|
|
1756
|
+
} return ptr; }
|
|
1757
|
+
function getInheritedInstance(class_, ptr) { ptr = getBasestPointer(class_, ptr); return registeredInstances[ptr]; }
|
|
1758
|
+
function makeClassHandle(prototype, record) { if (!record.ptrType || !record.ptr) {
|
|
1759
|
+
throwInternalError("makeClassHandle requires ptr and ptrType");
|
|
1760
|
+
} var hasSmartPtrType = !!record.smartPtrType; var hasSmartPtr = !!record.smartPtr; if (hasSmartPtrType !== hasSmartPtr) {
|
|
1761
|
+
throwInternalError("Both smartPtrType and smartPtr must be specified");
|
|
1762
|
+
} record.count = { value: 1 }; return attachFinalizer(Object.create(prototype, { $$: { value: record } })); }
|
|
1763
|
+
function RegisteredPointer_fromWireType(ptr) { var rawPointer = this.getPointee(ptr); if (!rawPointer) {
|
|
1764
|
+
this.destructor(ptr);
|
|
1765
|
+
return null;
|
|
1766
|
+
} var registeredInstance = getInheritedInstance(this.registeredClass, rawPointer); if (undefined !== registeredInstance) {
|
|
1767
|
+
if (0 === registeredInstance.$$.count.value) {
|
|
1768
|
+
registeredInstance.$$.ptr = rawPointer;
|
|
1769
|
+
registeredInstance.$$.smartPtr = ptr;
|
|
1770
|
+
return registeredInstance["clone"]();
|
|
1771
|
+
}
|
|
1772
|
+
else {
|
|
1773
|
+
var rv = registeredInstance["clone"]();
|
|
1774
|
+
this.destructor(ptr);
|
|
1775
|
+
return rv;
|
|
1776
|
+
}
|
|
1777
|
+
} function makeDefaultHandle() { if (this.isSmartPointer) {
|
|
1778
|
+
return makeClassHandle(this.registeredClass.instancePrototype, { ptrType: this.pointeeType, ptr: rawPointer, smartPtrType: this, smartPtr: ptr });
|
|
1779
|
+
}
|
|
1780
|
+
else {
|
|
1781
|
+
return makeClassHandle(this.registeredClass.instancePrototype, { ptrType: this, ptr: ptr });
|
|
1782
|
+
} } var actualType = this.registeredClass.getActualType(rawPointer); var registeredPointerRecord = registeredPointers[actualType]; if (!registeredPointerRecord) {
|
|
1783
|
+
return makeDefaultHandle.call(this);
|
|
1784
|
+
} var toType; if (this.isConst) {
|
|
1785
|
+
toType = registeredPointerRecord.constPointerType;
|
|
1786
|
+
}
|
|
1787
|
+
else {
|
|
1788
|
+
toType = registeredPointerRecord.pointerType;
|
|
1789
|
+
} var dp = downcastPointer(rawPointer, this.registeredClass, toType.registeredClass); if (dp === null) {
|
|
1790
|
+
return makeDefaultHandle.call(this);
|
|
1791
|
+
} if (this.isSmartPointer) {
|
|
1792
|
+
return makeClassHandle(toType.registeredClass.instancePrototype, { ptrType: toType, ptr: dp, smartPtrType: this, smartPtr: ptr });
|
|
1793
|
+
}
|
|
1794
|
+
else {
|
|
1795
|
+
return makeClassHandle(toType.registeredClass.instancePrototype, { ptrType: toType, ptr: dp });
|
|
1796
|
+
} }
|
|
1797
|
+
function attachFinalizer(handle) { if ("undefined" === typeof FinalizationRegistry) {
|
|
1798
|
+
attachFinalizer = handle => handle;
|
|
1799
|
+
return handle;
|
|
1800
|
+
} finalizationRegistry = new FinalizationRegistry(info => { releaseClassHandle(info.$$); }); attachFinalizer = handle => { var $$ = handle.$$; var hasSmartPtr = !!$$.smartPtr; if (hasSmartPtr) {
|
|
1801
|
+
var info = { $$: $$ };
|
|
1802
|
+
finalizationRegistry.register(handle, info, handle);
|
|
1803
|
+
} return handle; }; detachFinalizer = handle => finalizationRegistry.unregister(handle); return attachFinalizer(handle); }
|
|
1804
|
+
function ClassHandle_clone() { if (!this.$$.ptr) {
|
|
1805
|
+
throwInstanceAlreadyDeleted(this);
|
|
1806
|
+
} if (this.$$.preservePointerOnDelete) {
|
|
1807
|
+
this.$$.count.value += 1;
|
|
1808
|
+
return this;
|
|
1809
|
+
}
|
|
1810
|
+
else {
|
|
1811
|
+
var clone = attachFinalizer(Object.create(Object.getPrototypeOf(this), { $$: { value: shallowCopyInternalPointer(this.$$) } }));
|
|
1812
|
+
clone.$$.count.value += 1;
|
|
1813
|
+
clone.$$.deleteScheduled = false;
|
|
1814
|
+
return clone;
|
|
1815
|
+
} }
|
|
1816
|
+
function ClassHandle_delete() { if (!this.$$.ptr) {
|
|
1817
|
+
throwInstanceAlreadyDeleted(this);
|
|
1818
|
+
} if (this.$$.deleteScheduled && !this.$$.preservePointerOnDelete) {
|
|
1819
|
+
throwBindingError("Object already scheduled for deletion");
|
|
1820
|
+
} detachFinalizer(this); releaseClassHandle(this.$$); if (!this.$$.preservePointerOnDelete) {
|
|
1821
|
+
this.$$.smartPtr = undefined;
|
|
1822
|
+
this.$$.ptr = undefined;
|
|
1823
|
+
} }
|
|
1824
|
+
function ClassHandle_isDeleted() { return !this.$$.ptr; }
|
|
1825
|
+
function ClassHandle_deleteLater() { if (!this.$$.ptr) {
|
|
1826
|
+
throwInstanceAlreadyDeleted(this);
|
|
1827
|
+
} if (this.$$.deleteScheduled && !this.$$.preservePointerOnDelete) {
|
|
1828
|
+
throwBindingError("Object already scheduled for deletion");
|
|
1829
|
+
} deletionQueue.push(this); if (deletionQueue.length === 1 && delayFunction) {
|
|
1830
|
+
delayFunction(flushPendingDeletes);
|
|
1831
|
+
} this.$$.deleteScheduled = true; return this; }
|
|
1832
|
+
function init_ClassHandle() { ClassHandle.prototype["isAliasOf"] = ClassHandle_isAliasOf; ClassHandle.prototype["clone"] = ClassHandle_clone; ClassHandle.prototype["delete"] = ClassHandle_delete; ClassHandle.prototype["isDeleted"] = ClassHandle_isDeleted; ClassHandle.prototype["deleteLater"] = ClassHandle_deleteLater; }
|
|
1833
|
+
function ClassHandle() { }
|
|
1834
|
+
function ensureOverloadTable(proto, methodName, humanName) { if (undefined === proto[methodName].overloadTable) {
|
|
1835
|
+
var prevFunc = proto[methodName];
|
|
1836
|
+
proto[methodName] = function () { if (!proto[methodName].overloadTable.hasOwnProperty(arguments.length)) {
|
|
1837
|
+
throwBindingError("Function '" + humanName + "' called with an invalid number of arguments (" + arguments.length + ") - expects one of (" + proto[methodName].overloadTable + ")!");
|
|
1838
|
+
} return proto[methodName].overloadTable[arguments.length].apply(this, arguments); };
|
|
1839
|
+
proto[methodName].overloadTable = [];
|
|
1840
|
+
proto[methodName].overloadTable[prevFunc.argCount] = prevFunc;
|
|
1841
|
+
} }
|
|
1842
|
+
function exposePublicSymbol(name, value, numArguments) { if (Module.hasOwnProperty(name)) {
|
|
1843
|
+
if (undefined === numArguments || undefined !== Module[name].overloadTable && undefined !== Module[name].overloadTable[numArguments]) {
|
|
1844
|
+
throwBindingError("Cannot register public name '" + name + "' twice");
|
|
1845
|
+
}
|
|
1846
|
+
ensureOverloadTable(Module, name, name);
|
|
1847
|
+
if (Module.hasOwnProperty(numArguments)) {
|
|
1848
|
+
throwBindingError("Cannot register multiple overloads of a function with the same number of arguments (" + numArguments + ")!");
|
|
1849
|
+
}
|
|
1850
|
+
Module[name].overloadTable[numArguments] = value;
|
|
1851
|
+
}
|
|
1852
|
+
else {
|
|
1853
|
+
Module[name] = value;
|
|
1854
|
+
if (undefined !== numArguments) {
|
|
1855
|
+
Module[name].numArguments = numArguments;
|
|
1856
|
+
}
|
|
1857
|
+
} }
|
|
1858
|
+
function RegisteredClass(name, constructor, instancePrototype, rawDestructor, baseClass, getActualType, upcast, downcast) { this.name = name; this.constructor = constructor; this.instancePrototype = instancePrototype; this.rawDestructor = rawDestructor; this.baseClass = baseClass; this.getActualType = getActualType; this.upcast = upcast; this.downcast = downcast; this.pureVirtualFunctions = []; }
|
|
1859
|
+
function upcastPointer(ptr, ptrClass, desiredClass) { while (ptrClass !== desiredClass) {
|
|
1860
|
+
if (!ptrClass.upcast) {
|
|
1861
|
+
throwBindingError("Expected null or instance of " + desiredClass.name + ", got an instance of " + ptrClass.name);
|
|
1862
|
+
}
|
|
1863
|
+
ptr = ptrClass.upcast(ptr);
|
|
1864
|
+
ptrClass = ptrClass.baseClass;
|
|
1865
|
+
} return ptr; }
|
|
1866
|
+
function constNoSmartPtrRawPointerToWireType(destructors, handle) { if (handle === null) {
|
|
1867
|
+
if (this.isReference) {
|
|
1868
|
+
throwBindingError("null is not a valid " + this.name);
|
|
1869
|
+
}
|
|
1870
|
+
return 0;
|
|
1871
|
+
} if (!handle.$$) {
|
|
1872
|
+
throwBindingError('Cannot pass "' + embindRepr(handle) + '" as a ' + this.name);
|
|
1873
|
+
} if (!handle.$$.ptr) {
|
|
1874
|
+
throwBindingError("Cannot pass deleted object as a pointer of type " + this.name);
|
|
1875
|
+
} var handleClass = handle.$$.ptrType.registeredClass; var ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass); return ptr; }
|
|
1876
|
+
function genericPointerToWireType(destructors, handle) { var ptr; if (handle === null) {
|
|
1877
|
+
if (this.isReference) {
|
|
1878
|
+
throwBindingError("null is not a valid " + this.name);
|
|
1879
|
+
}
|
|
1880
|
+
if (this.isSmartPointer) {
|
|
1881
|
+
ptr = this.rawConstructor();
|
|
1882
|
+
if (destructors !== null) {
|
|
1883
|
+
destructors.push(this.rawDestructor, ptr);
|
|
1884
|
+
}
|
|
1885
|
+
return ptr;
|
|
1886
|
+
}
|
|
1887
|
+
else {
|
|
1888
|
+
return 0;
|
|
1889
|
+
}
|
|
1890
|
+
} if (!handle.$$) {
|
|
1891
|
+
throwBindingError('Cannot pass "' + embindRepr(handle) + '" as a ' + this.name);
|
|
1892
|
+
} if (!handle.$$.ptr) {
|
|
1893
|
+
throwBindingError("Cannot pass deleted object as a pointer of type " + this.name);
|
|
1894
|
+
} if (!this.isConst && handle.$$.ptrType.isConst) {
|
|
1895
|
+
throwBindingError("Cannot convert argument of type " + (handle.$$.smartPtrType ? handle.$$.smartPtrType.name : handle.$$.ptrType.name) + " to parameter type " + this.name);
|
|
1896
|
+
} var handleClass = handle.$$.ptrType.registeredClass; ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass); if (this.isSmartPointer) {
|
|
1897
|
+
if (undefined === handle.$$.smartPtr) {
|
|
1898
|
+
throwBindingError("Passing raw pointer to smart pointer is illegal");
|
|
1899
|
+
}
|
|
1900
|
+
switch (this.sharingPolicy) {
|
|
1901
|
+
case 0:
|
|
1902
|
+
if (handle.$$.smartPtrType === this) {
|
|
1903
|
+
ptr = handle.$$.smartPtr;
|
|
1904
|
+
}
|
|
1905
|
+
else {
|
|
1906
|
+
throwBindingError("Cannot convert argument of type " + (handle.$$.smartPtrType ? handle.$$.smartPtrType.name : handle.$$.ptrType.name) + " to parameter type " + this.name);
|
|
1907
|
+
}
|
|
1908
|
+
break;
|
|
1909
|
+
case 1:
|
|
1910
|
+
ptr = handle.$$.smartPtr;
|
|
1911
|
+
break;
|
|
1912
|
+
case 2:
|
|
1913
|
+
if (handle.$$.smartPtrType === this) {
|
|
1914
|
+
ptr = handle.$$.smartPtr;
|
|
1915
|
+
}
|
|
1916
|
+
else {
|
|
1917
|
+
var clonedHandle = handle["clone"]();
|
|
1918
|
+
ptr = this.rawShare(ptr, Emval.toHandle(function () { clonedHandle["delete"](); }));
|
|
1919
|
+
if (destructors !== null) {
|
|
1920
|
+
destructors.push(this.rawDestructor, ptr);
|
|
1921
|
+
}
|
|
1922
|
+
}
|
|
1923
|
+
break;
|
|
1924
|
+
default: throwBindingError("Unsupporting sharing policy");
|
|
1925
|
+
}
|
|
1926
|
+
} return ptr; }
|
|
1927
|
+
function nonConstNoSmartPtrRawPointerToWireType(destructors, handle) { if (handle === null) {
|
|
1928
|
+
if (this.isReference) {
|
|
1929
|
+
throwBindingError("null is not a valid " + this.name);
|
|
1930
|
+
}
|
|
1931
|
+
return 0;
|
|
1932
|
+
} if (!handle.$$) {
|
|
1933
|
+
throwBindingError('Cannot pass "' + embindRepr(handle) + '" as a ' + this.name);
|
|
1934
|
+
} if (!handle.$$.ptr) {
|
|
1935
|
+
throwBindingError("Cannot pass deleted object as a pointer of type " + this.name);
|
|
1936
|
+
} if (handle.$$.ptrType.isConst) {
|
|
1937
|
+
throwBindingError("Cannot convert argument of type " + handle.$$.ptrType.name + " to parameter type " + this.name);
|
|
1938
|
+
} var handleClass = handle.$$.ptrType.registeredClass; var ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass); return ptr; }
|
|
1939
|
+
function simpleReadValueFromPointer(pointer) { return this["fromWireType"](HEAP32[pointer >> 2]); }
|
|
1940
|
+
function RegisteredPointer_getPointee(ptr) { if (this.rawGetPointee) {
|
|
1941
|
+
ptr = this.rawGetPointee(ptr);
|
|
1942
|
+
} return ptr; }
|
|
1943
|
+
function RegisteredPointer_destructor(ptr) { if (this.rawDestructor) {
|
|
1944
|
+
this.rawDestructor(ptr);
|
|
1945
|
+
} }
|
|
1946
|
+
function RegisteredPointer_deleteObject(handle) { if (handle !== null) {
|
|
1947
|
+
handle["delete"]();
|
|
1948
|
+
} }
|
|
1949
|
+
function init_RegisteredPointer() { RegisteredPointer.prototype.getPointee = RegisteredPointer_getPointee; RegisteredPointer.prototype.destructor = RegisteredPointer_destructor; RegisteredPointer.prototype["argPackAdvance"] = 8; RegisteredPointer.prototype["readValueFromPointer"] = simpleReadValueFromPointer; RegisteredPointer.prototype["deleteObject"] = RegisteredPointer_deleteObject; RegisteredPointer.prototype["fromWireType"] = RegisteredPointer_fromWireType; }
|
|
1950
|
+
function RegisteredPointer(name, registeredClass, isReference, isConst, isSmartPointer, pointeeType, sharingPolicy, rawGetPointee, rawConstructor, rawShare, rawDestructor) { this.name = name; this.registeredClass = registeredClass; this.isReference = isReference; this.isConst = isConst; this.isSmartPointer = isSmartPointer; this.pointeeType = pointeeType; this.sharingPolicy = sharingPolicy; this.rawGetPointee = rawGetPointee; this.rawConstructor = rawConstructor; this.rawShare = rawShare; this.rawDestructor = rawDestructor; if (!isSmartPointer && registeredClass.baseClass === undefined) {
|
|
1951
|
+
if (isConst) {
|
|
1952
|
+
this["toWireType"] = constNoSmartPtrRawPointerToWireType;
|
|
1953
|
+
this.destructorFunction = null;
|
|
1954
|
+
}
|
|
1955
|
+
else {
|
|
1956
|
+
this["toWireType"] = nonConstNoSmartPtrRawPointerToWireType;
|
|
1957
|
+
this.destructorFunction = null;
|
|
1958
|
+
}
|
|
1959
|
+
}
|
|
1960
|
+
else {
|
|
1961
|
+
this["toWireType"] = genericPointerToWireType;
|
|
1962
|
+
} }
|
|
1963
|
+
function replacePublicSymbol(name, value, numArguments) { if (!Module.hasOwnProperty(name)) {
|
|
1964
|
+
throwInternalError("Replacing nonexistant public symbol");
|
|
1965
|
+
} if (undefined !== Module[name].overloadTable && undefined !== numArguments) {
|
|
1966
|
+
Module[name].overloadTable[numArguments] = value;
|
|
1967
|
+
}
|
|
1968
|
+
else {
|
|
1969
|
+
Module[name] = value;
|
|
1970
|
+
Module[name].argCount = numArguments;
|
|
1971
|
+
} }
|
|
1972
|
+
function dynCallLegacy(sig, ptr, args) { var f = Module["dynCall_" + sig]; return args && args.length ? f.apply(null, [ptr].concat(args)) : f.call(null, ptr); }
|
|
1973
|
+
var wasmTableMirror = [];
|
|
1974
|
+
function getWasmTableEntry(funcPtr) { var func = wasmTableMirror[funcPtr]; if (!func) {
|
|
1975
|
+
if (funcPtr >= wasmTableMirror.length)
|
|
1976
|
+
wasmTableMirror.length = funcPtr + 1;
|
|
1977
|
+
wasmTableMirror[funcPtr] = func = wasmTable.get(funcPtr);
|
|
1978
|
+
} return func; }
|
|
1979
|
+
function dynCall(sig, ptr, args) { if (sig.includes("j")) {
|
|
1980
|
+
return dynCallLegacy(sig, ptr, args);
|
|
1981
|
+
} var rtn = getWasmTableEntry(ptr).apply(null, args); return rtn; }
|
|
1982
|
+
function getDynCaller(sig, ptr) { var argCache = []; return function () { argCache.length = 0; Object.assign(argCache, arguments); return dynCall(sig, ptr, argCache); }; }
|
|
1983
|
+
function embind__requireFunction(signature, rawFunction) { signature = readLatin1String(signature); function makeDynCaller() { if (signature.includes("j")) {
|
|
1984
|
+
return getDynCaller(signature, rawFunction);
|
|
1985
|
+
} return getWasmTableEntry(rawFunction); } var fp = makeDynCaller(); if (typeof fp != "function") {
|
|
1986
|
+
throwBindingError("unknown function pointer with signature " + signature + ": " + rawFunction);
|
|
1987
|
+
} return fp; }
|
|
1988
|
+
var UnboundTypeError = undefined;
|
|
1989
|
+
function getTypeName(type) { var ptr = ___getTypeName(type); var rv = readLatin1String(ptr); _free(ptr); return rv; }
|
|
1990
|
+
function throwUnboundTypeError(message, types) { var unboundTypes = []; var seen = {}; function visit(type) { if (seen[type]) {
|
|
1991
|
+
return;
|
|
1992
|
+
} if (registeredTypes[type]) {
|
|
1993
|
+
return;
|
|
1994
|
+
} if (typeDependencies[type]) {
|
|
1995
|
+
typeDependencies[type].forEach(visit);
|
|
1996
|
+
return;
|
|
1997
|
+
} unboundTypes.push(type); seen[type] = true; } types.forEach(visit); throw new UnboundTypeError(message + ": " + unboundTypes.map(getTypeName).join([", "])); }
|
|
1998
|
+
function __embind_register_class(rawType, rawPointerType, rawConstPointerType, baseClassRawType, getActualTypeSignature, getActualType, upcastSignature, upcast, downcastSignature, downcast, name, destructorSignature, rawDestructor) { name = readLatin1String(name); getActualType = embind__requireFunction(getActualTypeSignature, getActualType); if (upcast) {
|
|
1999
|
+
upcast = embind__requireFunction(upcastSignature, upcast);
|
|
2000
|
+
} if (downcast) {
|
|
2001
|
+
downcast = embind__requireFunction(downcastSignature, downcast);
|
|
2002
|
+
} rawDestructor = embind__requireFunction(destructorSignature, rawDestructor); var legalFunctionName = makeLegalFunctionName(name); exposePublicSymbol(legalFunctionName, function () { throwUnboundTypeError("Cannot construct " + name + " due to unbound types", [baseClassRawType]); }); whenDependentTypesAreResolved([rawType, rawPointerType, rawConstPointerType], baseClassRawType ? [baseClassRawType] : [], function (base) { base = base[0]; var baseClass; var basePrototype; if (baseClassRawType) {
|
|
2003
|
+
baseClass = base.registeredClass;
|
|
2004
|
+
basePrototype = baseClass.instancePrototype;
|
|
2005
|
+
}
|
|
2006
|
+
else {
|
|
2007
|
+
basePrototype = ClassHandle.prototype;
|
|
2008
|
+
} var constructor = createNamedFunction(legalFunctionName, function () { if (Object.getPrototypeOf(this) !== instancePrototype) {
|
|
2009
|
+
throw new BindingError("Use 'new' to construct " + name);
|
|
2010
|
+
} if (undefined === registeredClass.constructor_body) {
|
|
2011
|
+
throw new BindingError(name + " has no accessible constructor");
|
|
2012
|
+
} var body = registeredClass.constructor_body[arguments.length]; if (undefined === body) {
|
|
2013
|
+
throw new BindingError("Tried to invoke ctor of " + name + " with invalid number of parameters (" + arguments.length + ") - expected (" + Object.keys(registeredClass.constructor_body).toString() + ") parameters instead!");
|
|
2014
|
+
} return body.apply(this, arguments); }); var instancePrototype = Object.create(basePrototype, { constructor: { value: constructor } }); constructor.prototype = instancePrototype; var registeredClass = new RegisteredClass(name, constructor, instancePrototype, rawDestructor, baseClass, getActualType, upcast, downcast); var referenceConverter = new RegisteredPointer(name, registeredClass, true, false, false); var pointerConverter = new RegisteredPointer(name + "*", registeredClass, false, false, false); var constPointerConverter = new RegisteredPointer(name + " const*", registeredClass, false, true, false); registeredPointers[rawType] = { pointerType: pointerConverter, constPointerType: constPointerConverter }; replacePublicSymbol(legalFunctionName, constructor); return [referenceConverter, pointerConverter, constPointerConverter]; }); }
|
|
2015
|
+
function heap32VectorToArray(count, firstElement) { var array = []; for (var i = 0; i < count; i++) {
|
|
2016
|
+
array.push(HEAPU32[firstElement + i * 4 >> 2]);
|
|
2017
|
+
} return array; }
|
|
2018
|
+
function runDestructors(destructors) { while (destructors.length) {
|
|
2019
|
+
var ptr = destructors.pop();
|
|
2020
|
+
var del = destructors.pop();
|
|
2021
|
+
del(ptr);
|
|
2022
|
+
} }
|
|
2023
|
+
function new_(constructor, argumentList) { if (!(constructor instanceof Function)) {
|
|
2024
|
+
throw new TypeError("new_ called with constructor type " + typeof constructor + " which is not a function");
|
|
2025
|
+
} var dummy = createNamedFunction(constructor.name || "unknownFunctionName", function () { }); dummy.prototype = constructor.prototype; var obj = new dummy; var r = constructor.apply(obj, argumentList); return r instanceof Object ? r : obj; }
|
|
2026
|
+
function craftInvokerFunction(humanName, argTypes, classType, cppInvokerFunc, cppTargetFunc, isAsync) { var argCount = argTypes.length; if (argCount < 2) {
|
|
2027
|
+
throwBindingError("argTypes array size mismatch! Must at least get return value and 'this' types!");
|
|
2028
|
+
} var isClassMethodFunc = argTypes[1] !== null && classType !== null; var needsDestructorStack = false; for (var i = 1; i < argTypes.length; ++i) {
|
|
2029
|
+
if (argTypes[i] !== null && argTypes[i].destructorFunction === undefined) {
|
|
2030
|
+
needsDestructorStack = true;
|
|
2031
|
+
break;
|
|
2032
|
+
}
|
|
2033
|
+
} var returns = argTypes[0].name !== "void"; var argsList = ""; var argsListWired = ""; for (var i = 0; i < argCount - 2; ++i) {
|
|
2034
|
+
argsList += (i !== 0 ? ", " : "") + "arg" + i;
|
|
2035
|
+
argsListWired += (i !== 0 ? ", " : "") + "arg" + i + "Wired";
|
|
2036
|
+
} var invokerFnBody = "return function " + makeLegalFunctionName(humanName) + "(" + argsList + ") {\n" + "if (arguments.length !== " + (argCount - 2) + ") {\n" + "throwBindingError('function " + humanName + " called with ' + arguments.length + ' arguments, expected " + (argCount - 2) + " args!');\n" + "}\n"; if (needsDestructorStack) {
|
|
2037
|
+
invokerFnBody += "var destructors = [];\n";
|
|
2038
|
+
} var dtorStack = needsDestructorStack ? "destructors" : "null"; var args1 = ["throwBindingError", "invoker", "fn", "runDestructors", "retType", "classParam"]; var args2 = [throwBindingError, cppInvokerFunc, cppTargetFunc, runDestructors, argTypes[0], argTypes[1]]; if (isClassMethodFunc) {
|
|
2039
|
+
invokerFnBody += "var thisWired = classParam.toWireType(" + dtorStack + ", this);\n";
|
|
2040
|
+
} for (var i = 0; i < argCount - 2; ++i) {
|
|
2041
|
+
invokerFnBody += "var arg" + i + "Wired = argType" + i + ".toWireType(" + dtorStack + ", arg" + i + "); // " + argTypes[i + 2].name + "\n";
|
|
2042
|
+
args1.push("argType" + i);
|
|
2043
|
+
args2.push(argTypes[i + 2]);
|
|
2044
|
+
} if (isClassMethodFunc) {
|
|
2045
|
+
argsListWired = "thisWired" + (argsListWired.length > 0 ? ", " : "") + argsListWired;
|
|
2046
|
+
} invokerFnBody += (returns || isAsync ? "var rv = " : "") + "invoker(fn" + (argsListWired.length > 0 ? ", " : "") + argsListWired + ");\n"; if (needsDestructorStack) {
|
|
2047
|
+
invokerFnBody += "runDestructors(destructors);\n";
|
|
2048
|
+
}
|
|
2049
|
+
else {
|
|
2050
|
+
for (var i = isClassMethodFunc ? 1 : 2; i < argTypes.length; ++i) {
|
|
2051
|
+
var paramName = i === 1 ? "thisWired" : "arg" + (i - 2) + "Wired";
|
|
2052
|
+
if (argTypes[i].destructorFunction !== null) {
|
|
2053
|
+
invokerFnBody += paramName + "_dtor(" + paramName + "); // " + argTypes[i].name + "\n";
|
|
2054
|
+
args1.push(paramName + "_dtor");
|
|
2055
|
+
args2.push(argTypes[i].destructorFunction);
|
|
2056
|
+
}
|
|
2057
|
+
}
|
|
2058
|
+
} if (returns) {
|
|
2059
|
+
invokerFnBody += "var ret = retType.fromWireType(rv);\n" + "return ret;\n";
|
|
2060
|
+
}
|
|
2061
|
+
else { } invokerFnBody += "}\n"; args1.push(invokerFnBody); var invokerFunction = new_(Function, args1).apply(null, args2); return invokerFunction; }
|
|
2062
|
+
function __embind_register_class_constructor(rawClassType, argCount, rawArgTypesAddr, invokerSignature, invoker, rawConstructor) { assert(argCount > 0); var rawArgTypes = heap32VectorToArray(argCount, rawArgTypesAddr); invoker = embind__requireFunction(invokerSignature, invoker); whenDependentTypesAreResolved([], [rawClassType], function (classType) { classType = classType[0]; var humanName = "constructor " + classType.name; if (undefined === classType.registeredClass.constructor_body) {
|
|
2063
|
+
classType.registeredClass.constructor_body = [];
|
|
2064
|
+
} if (undefined !== classType.registeredClass.constructor_body[argCount - 1]) {
|
|
2065
|
+
throw new BindingError("Cannot register multiple constructors with identical number of parameters (" + (argCount - 1) + ") for class '" + classType.name + "'! Overload resolution is currently only performed using the parameter count, not actual type info!");
|
|
2066
|
+
} classType.registeredClass.constructor_body[argCount - 1] = () => { throwUnboundTypeError("Cannot construct " + classType.name + " due to unbound types", rawArgTypes); }; whenDependentTypesAreResolved([], rawArgTypes, function (argTypes) { argTypes.splice(1, 0, null); classType.registeredClass.constructor_body[argCount - 1] = craftInvokerFunction(humanName, argTypes, null, invoker, rawConstructor); return []; }); return []; }); }
|
|
2067
|
+
function validateThis(this_, classType, humanName) { if (!(this_ instanceof Object)) {
|
|
2068
|
+
throwBindingError(humanName + ' with invalid "this": ' + this_);
|
|
2069
|
+
} if (!(this_ instanceof classType.registeredClass.constructor)) {
|
|
2070
|
+
throwBindingError(humanName + ' incompatible with "this" of type ' + this_.constructor.name);
|
|
2071
|
+
} if (!this_.$$.ptr) {
|
|
2072
|
+
throwBindingError("cannot call emscripten binding method " + humanName + " on deleted object");
|
|
2073
|
+
} return upcastPointer(this_.$$.ptr, this_.$$.ptrType.registeredClass, classType.registeredClass); }
|
|
2074
|
+
function __embind_register_class_property(classType, fieldName, getterReturnType, getterSignature, getter, getterContext, setterArgumentType, setterSignature, setter, setterContext) { fieldName = readLatin1String(fieldName); getter = embind__requireFunction(getterSignature, getter); whenDependentTypesAreResolved([], [classType], function (classType) { classType = classType[0]; var humanName = classType.name + "." + fieldName; var desc = { get: function () { throwUnboundTypeError("Cannot access " + humanName + " due to unbound types", [getterReturnType, setterArgumentType]); }, enumerable: true, configurable: true }; if (setter) {
|
|
2075
|
+
desc.set = () => { throwUnboundTypeError("Cannot access " + humanName + " due to unbound types", [getterReturnType, setterArgumentType]); };
|
|
2076
|
+
}
|
|
2077
|
+
else {
|
|
2078
|
+
desc.set = v => { throwBindingError(humanName + " is a read-only property"); };
|
|
2079
|
+
} Object.defineProperty(classType.registeredClass.instancePrototype, fieldName, desc); whenDependentTypesAreResolved([], setter ? [getterReturnType, setterArgumentType] : [getterReturnType], function (types) { var getterReturnType = types[0]; var desc = { get: function () { var ptr = validateThis(this, classType, humanName + " getter"); return getterReturnType["fromWireType"](getter(getterContext, ptr)); }, enumerable: true }; if (setter) {
|
|
2080
|
+
setter = embind__requireFunction(setterSignature, setter);
|
|
2081
|
+
var setterArgumentType = types[1];
|
|
2082
|
+
desc.set = function (v) { var ptr = validateThis(this, classType, humanName + " setter"); var destructors = []; setter(setterContext, ptr, setterArgumentType["toWireType"](destructors, v)); runDestructors(destructors); };
|
|
2083
|
+
} Object.defineProperty(classType.registeredClass.instancePrototype, fieldName, desc); return []; }); return []; }); }
|
|
2084
|
+
var emval_free_list = [];
|
|
2085
|
+
var emval_handle_array = [{}, { value: undefined }, { value: null }, { value: true }, { value: false }];
|
|
2086
|
+
function __emval_decref(handle) { if (handle > 4 && 0 === --emval_handle_array[handle].refcount) {
|
|
2087
|
+
emval_handle_array[handle] = undefined;
|
|
2088
|
+
emval_free_list.push(handle);
|
|
2089
|
+
} }
|
|
2090
|
+
function count_emval_handles() { var count = 0; for (var i = 5; i < emval_handle_array.length; ++i) {
|
|
2091
|
+
if (emval_handle_array[i] !== undefined) {
|
|
2092
|
+
++count;
|
|
2093
|
+
}
|
|
2094
|
+
} return count; }
|
|
2095
|
+
function get_first_emval() { for (var i = 5; i < emval_handle_array.length; ++i) {
|
|
2096
|
+
if (emval_handle_array[i] !== undefined) {
|
|
2097
|
+
return emval_handle_array[i];
|
|
2098
|
+
}
|
|
2099
|
+
} return null; }
|
|
2100
|
+
function init_emval() { Module["count_emval_handles"] = count_emval_handles; Module["get_first_emval"] = get_first_emval; }
|
|
2101
|
+
var Emval = { toValue: handle => { if (!handle) {
|
|
2102
|
+
throwBindingError("Cannot use deleted val. handle = " + handle);
|
|
2103
|
+
} return emval_handle_array[handle].value; }, toHandle: value => { switch (value) {
|
|
2104
|
+
case undefined: return 1;
|
|
2105
|
+
case null: return 2;
|
|
2106
|
+
case true: return 3;
|
|
2107
|
+
case false: return 4;
|
|
2108
|
+
default: {
|
|
2109
|
+
var handle = emval_free_list.length ? emval_free_list.pop() : emval_handle_array.length;
|
|
2110
|
+
emval_handle_array[handle] = { refcount: 1, value: value };
|
|
2111
|
+
return handle;
|
|
2112
|
+
}
|
|
2113
|
+
} } };
|
|
2114
|
+
function __embind_register_emval(rawType, name) { name = readLatin1String(name); registerType(rawType, { name: name, "fromWireType": function (handle) { var rv = Emval.toValue(handle); __emval_decref(handle); return rv; }, "toWireType": function (destructors, value) { return Emval.toHandle(value); }, "argPackAdvance": 8, "readValueFromPointer": simpleReadValueFromPointer, destructorFunction: null }); }
|
|
2115
|
+
function embindRepr(v) { if (v === null) {
|
|
2116
|
+
return "null";
|
|
2117
|
+
} var t = typeof v; if (t === "object" || t === "array" || t === "function") {
|
|
2118
|
+
return v.toString();
|
|
2119
|
+
}
|
|
2120
|
+
else {
|
|
2121
|
+
return "" + v;
|
|
2122
|
+
} }
|
|
2123
|
+
function floatReadValueFromPointer(name, shift) { switch (shift) {
|
|
2124
|
+
case 2: return function (pointer) { return this["fromWireType"](HEAPF32[pointer >> 2]); };
|
|
2125
|
+
case 3: return function (pointer) { return this["fromWireType"](HEAPF64[pointer >> 3]); };
|
|
2126
|
+
default: throw new TypeError("Unknown float type: " + name);
|
|
2127
|
+
} }
|
|
2128
|
+
function __embind_register_float(rawType, name, size) { var shift = getShiftFromSize(size); name = readLatin1String(name); registerType(rawType, { name: name, "fromWireType": function (value) { return value; }, "toWireType": function (destructors, value) { return value; }, "argPackAdvance": 8, "readValueFromPointer": floatReadValueFromPointer(name, shift), destructorFunction: null }); }
|
|
2129
|
+
function __embind_register_function(name, argCount, rawArgTypesAddr, signature, rawInvoker, fn, isAsync) { var argTypes = heap32VectorToArray(argCount, rawArgTypesAddr); name = readLatin1String(name); rawInvoker = embind__requireFunction(signature, rawInvoker); exposePublicSymbol(name, function () { throwUnboundTypeError("Cannot call " + name + " due to unbound types", argTypes); }, argCount - 1); whenDependentTypesAreResolved([], argTypes, function (argTypes) { var invokerArgsArray = [argTypes[0], null].concat(argTypes.slice(1)); replacePublicSymbol(name, craftInvokerFunction(name, invokerArgsArray, null, rawInvoker, fn, isAsync), argCount - 1); return []; }); }
|
|
2130
|
+
function integerReadValueFromPointer(name, shift, signed) { switch (shift) {
|
|
2131
|
+
case 0: return signed ? function readS8FromPointer(pointer) { return HEAP8[pointer]; } : function readU8FromPointer(pointer) { return HEAPU8[pointer]; };
|
|
2132
|
+
case 1: return signed ? function readS16FromPointer(pointer) { return HEAP16[pointer >> 1]; } : function readU16FromPointer(pointer) { return HEAPU16[pointer >> 1]; };
|
|
2133
|
+
case 2: return signed ? function readS32FromPointer(pointer) { return HEAP32[pointer >> 2]; } : function readU32FromPointer(pointer) { return HEAPU32[pointer >> 2]; };
|
|
2134
|
+
default: throw new TypeError("Unknown integer type: " + name);
|
|
2135
|
+
} }
|
|
2136
|
+
function __embind_register_integer(primitiveType, name, size, minRange, maxRange) { name = readLatin1String(name); if (maxRange === -1) {
|
|
2137
|
+
maxRange = 4294967295;
|
|
2138
|
+
} var shift = getShiftFromSize(size); var fromWireType = value => value; if (minRange === 0) {
|
|
2139
|
+
var bitshift = 32 - 8 * size;
|
|
2140
|
+
fromWireType = value => value << bitshift >>> bitshift;
|
|
2141
|
+
} var isUnsignedType = name.includes("unsigned"); var checkAssertions = (value, toTypeName) => { }; var toWireType; if (isUnsignedType) {
|
|
2142
|
+
toWireType = function (destructors, value) { checkAssertions(value, this.name); return value >>> 0; };
|
|
2143
|
+
}
|
|
2144
|
+
else {
|
|
2145
|
+
toWireType = function (destructors, value) { checkAssertions(value, this.name); return value; };
|
|
2146
|
+
} registerType(primitiveType, { name: name, "fromWireType": fromWireType, "toWireType": toWireType, "argPackAdvance": 8, "readValueFromPointer": integerReadValueFromPointer(name, shift, minRange !== 0), destructorFunction: null }); }
|
|
2147
|
+
function __embind_register_memory_view(rawType, dataTypeIndex, name) { var typeMapping = [Int8Array, Uint8Array, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, Float64Array]; var TA = typeMapping[dataTypeIndex]; function decodeMemoryView(handle) { handle = handle >> 2; var heap = HEAPU32; var size = heap[handle]; var data = heap[handle + 1]; return new TA(heap.buffer, data, size); } name = readLatin1String(name); registerType(rawType, { name: name, "fromWireType": decodeMemoryView, "argPackAdvance": 8, "readValueFromPointer": decodeMemoryView }, { ignoreDuplicateRegistrations: true }); }
|
|
2148
|
+
function __embind_register_std_string(rawType, name) { name = readLatin1String(name); var stdStringIsUTF8 = name === "std::string"; registerType(rawType, { name: name, "fromWireType": function (value) { var length = HEAPU32[value >> 2]; var payload = value + 4; var str; if (stdStringIsUTF8) {
|
|
2149
|
+
var decodeStartPtr = payload;
|
|
2150
|
+
for (var i = 0; i <= length; ++i) {
|
|
2151
|
+
var currentBytePtr = payload + i;
|
|
2152
|
+
if (i == length || HEAPU8[currentBytePtr] == 0) {
|
|
2153
|
+
var maxRead = currentBytePtr - decodeStartPtr;
|
|
2154
|
+
var stringSegment = UTF8ToString(decodeStartPtr, maxRead);
|
|
2155
|
+
if (str === undefined) {
|
|
2156
|
+
str = stringSegment;
|
|
2157
|
+
}
|
|
2158
|
+
else {
|
|
2159
|
+
str += String.fromCharCode(0);
|
|
2160
|
+
str += stringSegment;
|
|
2161
|
+
}
|
|
2162
|
+
decodeStartPtr = currentBytePtr + 1;
|
|
2163
|
+
}
|
|
2164
|
+
}
|
|
2165
|
+
}
|
|
2166
|
+
else {
|
|
2167
|
+
var a = new Array(length);
|
|
2168
|
+
for (var i = 0; i < length; ++i) {
|
|
2169
|
+
a[i] = String.fromCharCode(HEAPU8[payload + i]);
|
|
2170
|
+
}
|
|
2171
|
+
str = a.join("");
|
|
2172
|
+
} _free(value); return str; }, "toWireType": function (destructors, value) { if (value instanceof ArrayBuffer) {
|
|
2173
|
+
value = new Uint8Array(value);
|
|
2174
|
+
} var length; var valueIsOfTypeString = typeof value == "string"; if (!(valueIsOfTypeString || value instanceof Uint8Array || value instanceof Uint8ClampedArray || value instanceof Int8Array)) {
|
|
2175
|
+
throwBindingError("Cannot pass non-string to std::string");
|
|
2176
|
+
} if (stdStringIsUTF8 && valueIsOfTypeString) {
|
|
2177
|
+
length = lengthBytesUTF8(value);
|
|
2178
|
+
}
|
|
2179
|
+
else {
|
|
2180
|
+
length = value.length;
|
|
2181
|
+
} var base = _malloc(4 + length + 1); var ptr = base + 4; HEAPU32[base >> 2] = length; if (stdStringIsUTF8 && valueIsOfTypeString) {
|
|
2182
|
+
stringToUTF8(value, ptr, length + 1);
|
|
2183
|
+
}
|
|
2184
|
+
else {
|
|
2185
|
+
if (valueIsOfTypeString) {
|
|
2186
|
+
for (var i = 0; i < length; ++i) {
|
|
2187
|
+
var charCode = value.charCodeAt(i);
|
|
2188
|
+
if (charCode > 255) {
|
|
2189
|
+
_free(ptr);
|
|
2190
|
+
throwBindingError("String has UTF-16 code units that do not fit in 8 bits");
|
|
2191
|
+
}
|
|
2192
|
+
HEAPU8[ptr + i] = charCode;
|
|
2193
|
+
}
|
|
2194
|
+
}
|
|
2195
|
+
else {
|
|
2196
|
+
for (var i = 0; i < length; ++i) {
|
|
2197
|
+
HEAPU8[ptr + i] = value[i];
|
|
2198
|
+
}
|
|
2199
|
+
}
|
|
2200
|
+
} if (destructors !== null) {
|
|
2201
|
+
destructors.push(_free, base);
|
|
2202
|
+
} return base; }, "argPackAdvance": 8, "readValueFromPointer": simpleReadValueFromPointer, destructorFunction: function (ptr) { _free(ptr); } }); }
|
|
2203
|
+
var UTF16Decoder = typeof TextDecoder != "undefined" ? new TextDecoder("utf-16le") : undefined;
|
|
2204
|
+
function UTF16ToString(ptr, maxBytesToRead) { var endPtr = ptr; var idx = endPtr >> 1; var maxIdx = idx + maxBytesToRead / 2; while (!(idx >= maxIdx) && HEAPU16[idx])
|
|
2205
|
+
++idx; endPtr = idx << 1; if (endPtr - ptr > 32 && UTF16Decoder)
|
|
2206
|
+
return UTF16Decoder.decode(HEAPU8.subarray(ptr, endPtr)); var str = ""; for (var i = 0; !(i >= maxBytesToRead / 2); ++i) {
|
|
2207
|
+
var codeUnit = HEAP16[ptr + i * 2 >> 1];
|
|
2208
|
+
if (codeUnit == 0)
|
|
2209
|
+
break;
|
|
2210
|
+
str += String.fromCharCode(codeUnit);
|
|
2211
|
+
} return str; }
|
|
2212
|
+
function stringToUTF16(str, outPtr, maxBytesToWrite) { if (maxBytesToWrite === undefined) {
|
|
2213
|
+
maxBytesToWrite = 2147483647;
|
|
2214
|
+
} if (maxBytesToWrite < 2)
|
|
2215
|
+
return 0; maxBytesToWrite -= 2; var startPtr = outPtr; var numCharsToWrite = maxBytesToWrite < str.length * 2 ? maxBytesToWrite / 2 : str.length; for (var i = 0; i < numCharsToWrite; ++i) {
|
|
2216
|
+
var codeUnit = str.charCodeAt(i);
|
|
2217
|
+
HEAP16[outPtr >> 1] = codeUnit;
|
|
2218
|
+
outPtr += 2;
|
|
2219
|
+
} HEAP16[outPtr >> 1] = 0; return outPtr - startPtr; }
|
|
2220
|
+
function lengthBytesUTF16(str) { return str.length * 2; }
|
|
2221
|
+
function UTF32ToString(ptr, maxBytesToRead) { var i = 0; var str = ""; while (!(i >= maxBytesToRead / 4)) {
|
|
2222
|
+
var utf32 = HEAP32[ptr + i * 4 >> 2];
|
|
2223
|
+
if (utf32 == 0)
|
|
2224
|
+
break;
|
|
2225
|
+
++i;
|
|
2226
|
+
if (utf32 >= 65536) {
|
|
2227
|
+
var ch = utf32 - 65536;
|
|
2228
|
+
str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
|
|
2229
|
+
}
|
|
2230
|
+
else {
|
|
2231
|
+
str += String.fromCharCode(utf32);
|
|
2232
|
+
}
|
|
2233
|
+
} return str; }
|
|
2234
|
+
function stringToUTF32(str, outPtr, maxBytesToWrite) { if (maxBytesToWrite === undefined) {
|
|
2235
|
+
maxBytesToWrite = 2147483647;
|
|
2236
|
+
} if (maxBytesToWrite < 4)
|
|
2237
|
+
return 0; var startPtr = outPtr; var endPtr = startPtr + maxBytesToWrite - 4; for (var i = 0; i < str.length; ++i) {
|
|
2238
|
+
var codeUnit = str.charCodeAt(i);
|
|
2239
|
+
if (codeUnit >= 55296 && codeUnit <= 57343) {
|
|
2240
|
+
var trailSurrogate = str.charCodeAt(++i);
|
|
2241
|
+
codeUnit = 65536 + ((codeUnit & 1023) << 10) | trailSurrogate & 1023;
|
|
2242
|
+
}
|
|
2243
|
+
HEAP32[outPtr >> 2] = codeUnit;
|
|
2244
|
+
outPtr += 4;
|
|
2245
|
+
if (outPtr + 4 > endPtr)
|
|
2246
|
+
break;
|
|
2247
|
+
} HEAP32[outPtr >> 2] = 0; return outPtr - startPtr; }
|
|
2248
|
+
function lengthBytesUTF32(str) { var len = 0; for (var i = 0; i < str.length; ++i) {
|
|
2249
|
+
var codeUnit = str.charCodeAt(i);
|
|
2250
|
+
if (codeUnit >= 55296 && codeUnit <= 57343)
|
|
2251
|
+
++i;
|
|
2252
|
+
len += 4;
|
|
2253
|
+
} return len; }
|
|
2254
|
+
function __embind_register_std_wstring(rawType, charSize, name) { name = readLatin1String(name); var decodeString, encodeString, getHeap, lengthBytesUTF, shift; if (charSize === 2) {
|
|
2255
|
+
decodeString = UTF16ToString;
|
|
2256
|
+
encodeString = stringToUTF16;
|
|
2257
|
+
lengthBytesUTF = lengthBytesUTF16;
|
|
2258
|
+
getHeap = () => HEAPU16;
|
|
2259
|
+
shift = 1;
|
|
2260
|
+
}
|
|
2261
|
+
else if (charSize === 4) {
|
|
2262
|
+
decodeString = UTF32ToString;
|
|
2263
|
+
encodeString = stringToUTF32;
|
|
2264
|
+
lengthBytesUTF = lengthBytesUTF32;
|
|
2265
|
+
getHeap = () => HEAPU32;
|
|
2266
|
+
shift = 2;
|
|
2267
|
+
} registerType(rawType, { name: name, "fromWireType": function (value) { var length = HEAPU32[value >> 2]; var HEAP = getHeap(); var str; var decodeStartPtr = value + 4; for (var i = 0; i <= length; ++i) {
|
|
2268
|
+
var currentBytePtr = value + 4 + i * charSize;
|
|
2269
|
+
if (i == length || HEAP[currentBytePtr >> shift] == 0) {
|
|
2270
|
+
var maxReadBytes = currentBytePtr - decodeStartPtr;
|
|
2271
|
+
var stringSegment = decodeString(decodeStartPtr, maxReadBytes);
|
|
2272
|
+
if (str === undefined) {
|
|
2273
|
+
str = stringSegment;
|
|
2274
|
+
}
|
|
2275
|
+
else {
|
|
2276
|
+
str += String.fromCharCode(0);
|
|
2277
|
+
str += stringSegment;
|
|
2278
|
+
}
|
|
2279
|
+
decodeStartPtr = currentBytePtr + charSize;
|
|
2280
|
+
}
|
|
2281
|
+
} _free(value); return str; }, "toWireType": function (destructors, value) { if (!(typeof value == "string")) {
|
|
2282
|
+
throwBindingError("Cannot pass non-string to C++ string type " + name);
|
|
2283
|
+
} var length = lengthBytesUTF(value); var ptr = _malloc(4 + length + charSize); HEAPU32[ptr >> 2] = length >> shift; encodeString(value, ptr + 4, length + charSize); if (destructors !== null) {
|
|
2284
|
+
destructors.push(_free, ptr);
|
|
2285
|
+
} return ptr; }, "argPackAdvance": 8, "readValueFromPointer": simpleReadValueFromPointer, destructorFunction: function (ptr) { _free(ptr); } }); }
|
|
2286
|
+
function __embind_register_void(rawType, name) { name = readLatin1String(name); registerType(rawType, { isVoid: true, name: name, "argPackAdvance": 0, "fromWireType": function () { return undefined; }, "toWireType": function (destructors, o) { return undefined; } }); }
|
|
1617
2287
|
var nowIsMonotonic = true;
|
|
1618
2288
|
function __emscripten_get_now_is_monotonic() { return nowIsMonotonic; }
|
|
1619
2289
|
function _abort() { abort(""); }
|
|
@@ -1842,7 +2512,15 @@ var Module = (() => {
|
|
|
1842
2512
|
NODEFS.staticInit();
|
|
1843
2513
|
}
|
|
1844
2514
|
ERRNO_CODES = { "EPERM": 63, "ENOENT": 44, "ESRCH": 71, "EINTR": 27, "EIO": 29, "ENXIO": 60, "E2BIG": 1, "ENOEXEC": 45, "EBADF": 8, "ECHILD": 12, "EAGAIN": 6, "EWOULDBLOCK": 6, "ENOMEM": 48, "EACCES": 2, "EFAULT": 21, "ENOTBLK": 105, "EBUSY": 10, "EEXIST": 20, "EXDEV": 75, "ENODEV": 43, "ENOTDIR": 54, "EISDIR": 31, "EINVAL": 28, "ENFILE": 41, "EMFILE": 33, "ENOTTY": 59, "ETXTBSY": 74, "EFBIG": 22, "ENOSPC": 51, "ESPIPE": 70, "EROFS": 69, "EMLINK": 34, "EPIPE": 64, "EDOM": 18, "ERANGE": 68, "ENOMSG": 49, "EIDRM": 24, "ECHRNG": 106, "EL2NSYNC": 156, "EL3HLT": 107, "EL3RST": 108, "ELNRNG": 109, "EUNATCH": 110, "ENOCSI": 111, "EL2HLT": 112, "EDEADLK": 16, "ENOLCK": 46, "EBADE": 113, "EBADR": 114, "EXFULL": 115, "ENOANO": 104, "EBADRQC": 103, "EBADSLT": 102, "EDEADLOCK": 16, "EBFONT": 101, "ENOSTR": 100, "ENODATA": 116, "ETIME": 117, "ENOSR": 118, "ENONET": 119, "ENOPKG": 120, "EREMOTE": 121, "ENOLINK": 47, "EADV": 122, "ESRMNT": 123, "ECOMM": 124, "EPROTO": 65, "EMULTIHOP": 36, "EDOTDOT": 125, "EBADMSG": 9, "ENOTUNIQ": 126, "EBADFD": 127, "EREMCHG": 128, "ELIBACC": 129, "ELIBBAD": 130, "ELIBSCN": 131, "ELIBMAX": 132, "ELIBEXEC": 133, "ENOSYS": 52, "ENOTEMPTY": 55, "ENAMETOOLONG": 37, "ELOOP": 32, "EOPNOTSUPP": 138, "EPFNOSUPPORT": 139, "ECONNRESET": 15, "ENOBUFS": 42, "EAFNOSUPPORT": 5, "EPROTOTYPE": 67, "ENOTSOCK": 57, "ENOPROTOOPT": 50, "ESHUTDOWN": 140, "ECONNREFUSED": 14, "EADDRINUSE": 3, "ECONNABORTED": 13, "ENETUNREACH": 40, "ENETDOWN": 38, "ETIMEDOUT": 73, "EHOSTDOWN": 142, "EHOSTUNREACH": 23, "EINPROGRESS": 26, "EALREADY": 7, "EDESTADDRREQ": 17, "EMSGSIZE": 35, "EPROTONOSUPPORT": 66, "ESOCKTNOSUPPORT": 137, "EADDRNOTAVAIL": 4, "ENETRESET": 39, "EISCONN": 30, "ENOTCONN": 53, "ETOOMANYREFS": 141, "EUSERS": 136, "EDQUOT": 19, "ESTALE": 72, "ENOTSUP": 138, "ENOMEDIUM": 148, "EILSEQ": 25, "EOVERFLOW": 61, "ECANCELED": 11, "ENOTRECOVERABLE": 56, "EOWNERDEAD": 62, "ESTRPIPE": 135 };
|
|
1845
|
-
|
|
2515
|
+
embind_init_charCodes();
|
|
2516
|
+
BindingError = Module["BindingError"] = extendError(Error, "BindingError");
|
|
2517
|
+
InternalError = Module["InternalError"] = extendError(Error, "InternalError");
|
|
2518
|
+
init_ClassHandle();
|
|
2519
|
+
init_embind();
|
|
2520
|
+
init_RegisteredPointer();
|
|
2521
|
+
UnboundTypeError = Module["UnboundTypeError"] = extendError(Error, "UnboundTypeError");
|
|
2522
|
+
init_emval();
|
|
2523
|
+
var wasmImports = { "__assert_fail": ___assert_fail, "__cxa_throw": ___cxa_throw, "__syscall_faccessat": ___syscall_faccessat, "__syscall_fcntl64": ___syscall_fcntl64, "__syscall_ioctl": ___syscall_ioctl, "__syscall_openat": ___syscall_openat, "__syscall_rmdir": ___syscall_rmdir, "__syscall_unlinkat": ___syscall_unlinkat, "_embind_register_bigint": __embind_register_bigint, "_embind_register_bool": __embind_register_bool, "_embind_register_class": __embind_register_class, "_embind_register_class_constructor": __embind_register_class_constructor, "_embind_register_class_property": __embind_register_class_property, "_embind_register_emval": __embind_register_emval, "_embind_register_float": __embind_register_float, "_embind_register_function": __embind_register_function, "_embind_register_integer": __embind_register_integer, "_embind_register_memory_view": __embind_register_memory_view, "_embind_register_std_string": __embind_register_std_string, "_embind_register_std_wstring": __embind_register_std_wstring, "_embind_register_void": __embind_register_void, "_emscripten_get_now_is_monotonic": __emscripten_get_now_is_monotonic, "abort": _abort, "emscripten_asm_const_int": _emscripten_asm_const_int, "emscripten_date_now": _emscripten_date_now, "emscripten_get_now": _emscripten_get_now, "emscripten_memcpy_big": _emscripten_memcpy_big, "emscripten_resize_heap": _emscripten_resize_heap, "environ_get": _environ_get, "environ_sizes_get": _environ_sizes_get, "fd_close": _fd_close, "fd_read": _fd_read, "fd_seek": _fd_seek, "fd_write": _fd_write, "strftime_l": _strftime_l, "wasm_msgproc": wasm_msgproc };
|
|
1846
2524
|
var asm = createWasm();
|
|
1847
2525
|
var ___wasm_call_ctors = function () { return (___wasm_call_ctors = Module["asm"]["__wasm_call_ctors"]).apply(null, arguments); };
|
|
1848
2526
|
var _kmcmp_SetCompilerOptions = Module["_kmcmp_SetCompilerOptions"] = function () { return (_kmcmp_SetCompilerOptions = Module["_kmcmp_SetCompilerOptions"] = Module["asm"]["kmcmp_SetCompilerOptions"]).apply(null, arguments); };
|
|
@@ -1852,9 +2530,12 @@ var Module = (() => {
|
|
|
1852
2530
|
var _kmcmp_Wasm_ParseUnicodeSet = Module["_kmcmp_Wasm_ParseUnicodeSet"] = function () { return (_kmcmp_Wasm_ParseUnicodeSet = Module["_kmcmp_Wasm_ParseUnicodeSet"] = Module["asm"]["kmcmp_Wasm_ParseUnicodeSet"]).apply(null, arguments); };
|
|
1853
2531
|
var _kmcmp_ParseUnicodeSet = Module["_kmcmp_ParseUnicodeSet"] = function () { return (_kmcmp_ParseUnicodeSet = Module["_kmcmp_ParseUnicodeSet"] = Module["asm"]["kmcmp_ParseUnicodeSet"]).apply(null, arguments); };
|
|
1854
2532
|
var _kmcmp_CompileKeyboardFileToBuffer = Module["_kmcmp_CompileKeyboardFileToBuffer"] = function () { return (_kmcmp_CompileKeyboardFileToBuffer = Module["_kmcmp_CompileKeyboardFileToBuffer"] = Module["asm"]["kmcmp_CompileKeyboardFileToBuffer"]).apply(null, arguments); };
|
|
2533
|
+
var _malloc = function () { return (_malloc = Module["asm"]["malloc"]).apply(null, arguments); };
|
|
1855
2534
|
var _kmcmp_ValidateJsonFile = Module["_kmcmp_ValidateJsonFile"] = function () { return (_kmcmp_ValidateJsonFile = Module["_kmcmp_ValidateJsonFile"] = Module["asm"]["kmcmp_ValidateJsonFile"]).apply(null, arguments); };
|
|
1856
2535
|
var ___errno_location = function () { return (___errno_location = Module["asm"]["__errno_location"]).apply(null, arguments); };
|
|
1857
|
-
var
|
|
2536
|
+
var _free = function () { return (_free = Module["asm"]["free"]).apply(null, arguments); };
|
|
2537
|
+
var ___getTypeName = Module["___getTypeName"] = function () { return (___getTypeName = Module["___getTypeName"] = Module["asm"]["__getTypeName"]).apply(null, arguments); };
|
|
2538
|
+
var __embind_initialize_bindings = Module["__embind_initialize_bindings"] = function () { return (__embind_initialize_bindings = Module["__embind_initialize_bindings"] = Module["asm"]["_embind_initialize_bindings"]).apply(null, arguments); };
|
|
1858
2539
|
var stackSave = function () { return (stackSave = Module["asm"]["stackSave"]).apply(null, arguments); };
|
|
1859
2540
|
var stackRestore = function () { return (stackRestore = Module["asm"]["stackRestore"]).apply(null, arguments); };
|
|
1860
2541
|
var stackAlloc = function () { return (stackAlloc = Module["asm"]["stackAlloc"]).apply(null, arguments); };
|
|
@@ -1864,8 +2545,8 @@ var Module = (() => {
|
|
|
1864
2545
|
var dynCall_iiiiij = Module["dynCall_iiiiij"] = function () { return (dynCall_iiiiij = Module["dynCall_iiiiij"] = Module["asm"]["dynCall_iiiiij"]).apply(null, arguments); };
|
|
1865
2546
|
var dynCall_iiiiijj = Module["dynCall_iiiiijj"] = function () { return (dynCall_iiiiijj = Module["dynCall_iiiiijj"] = Module["asm"]["dynCall_iiiiijj"]).apply(null, arguments); };
|
|
1866
2547
|
var dynCall_iiiiiijj = Module["dynCall_iiiiiijj"] = function () { return (dynCall_iiiiiijj = Module["dynCall_iiiiiijj"] = Module["asm"]["dynCall_iiiiiijj"]).apply(null, arguments); };
|
|
1867
|
-
var ___start_em_js = Module["___start_em_js"] =
|
|
1868
|
-
var ___stop_em_js = Module["___stop_em_js"] =
|
|
2548
|
+
var ___start_em_js = Module["___start_em_js"] = 74596;
|
|
2549
|
+
var ___stop_em_js = Module["___stop_em_js"] = 74873;
|
|
1869
2550
|
Module["UTF8ToString"] = UTF8ToString;
|
|
1870
2551
|
Module["cwrap"] = cwrap;
|
|
1871
2552
|
var calledRun;
|